文章目录

引言

该项目是采用目前比较流行的​​SpringBoot​​​/​​SpringCloud​​构建微服务电商项目,项目叫 《果然新鲜》,实现一套串联的微服务电商项目,能完全掌握该知识,可以在一线城市拿到月薪25+k薪资。

完全符合一线城市微服务电商的需求,对中国程序猿学习微服务电商架构,有非常大的帮助,该项目涵盖从微服务电商需求讨论、数据库设计、技术选型、互联网安全架构、整合​​SpringCloud​​​各自组件、分布式基础设施、使​​Docker+k8s+jenkins​​​实现微服务自动化部署、项目上线域名配置、​​SEO​​优化、大数据统计分析等,实现一套完整的微服务解决方案。

《果然新鲜》电商项目(01)- 需求讨论与技术选型_tomcat

2.系统架构图

《果然新鲜》电商项目(01)- 需求讨论与技术选型_tomcat_02

2.环境要求

由于本项目对环境的要求非常高

建议电脑配置

  • CPU I5
  • 内存16GB

开发环境要求

  • JDK统一要求:JDK1.8
  • Maven统一管理依赖
  • 统一采用Docker环境部署
  • 编码统一采用UTF-8
  • 开发工具IDE或者Eclipse

3.技术选型

3.1 SpringBoot2.x+SpringCloud2.x构建微服务电商项目

  1. 使用SpringCloud Eureka作为注册中心,实现服务治理
  2. 使用Zuul网关框架管理服务请求入口
  3. 使用Ribbon实现本地负载均衡器和Feign HTTP客户端调用工具
  4. 使用Hystrix服务保护框架(服务降级、隔离、熔断、限流)
  5. 使用消息总线Stream RabbitMQ和Kafka
  6. 微服务API接口安全控制和单点登录系统CAS+JWT+OAuth2.0

3.2 分布式基础设施构建

  1. 分布式任务调度平台XXL-JOB
  2. 分布式日志采集系统ELK
  3. 分布式事务解决方案LCN
  4. 分布式锁解决方案Zookeeper、Redis
  5. 分布式配置中心(携程Apollo)
  6. 高并发分布式全局ID生成(雪花算法)
  7. 分布式Session框架Spring-Session
  8. 分布式服务追踪与调用链Zipkin

3.3 项目运营与部署环境

  1. 分布式设施环境,统一采用Docker安装
  2. 使用jenkins+docker+k8s实现自动部署
  3. 微服务API管理ApiSwagger
  4. 使用GitLab代码管理
  5. 统一采用第三方云数据库
  6. 使用七牛云服务器对静态资源实现加速

4.总结

《果然新鲜》电商项目(01)- 需求讨论与技术选型_java_03