SpringCloud微服务架构 黑马程序员-乐优商城项目实战

课程列表

SpringCloud微服务架构 黑马程序员-乐优商城项目实战:

440次播放 加入学习计划 课件下载
  • 课程介绍
  • 用户评论

乐优商城介绍

  • 乐优商城是一个全品类的电商购物网站(B2C)
  • 用户可以在线购买商品、加入购物车、下单、秒杀商品
  • 可以评论已购买商品
  • 管理员可以在后台管理商品的上下架、促销活动
  • 管理员可以监控商品销售状况
  • 客服可以在后台处理退款操作
  • 希望未来3到5年可以支持千万用户的使用

系统架构图



系统架构解读

整个乐优商城可以分为两部分:后台管理系统、前台门户系统

后台管理:

  • 商品管理,包括商品分类、品牌、商品规格等信息的管理
  • 销售管理,包括订单统计、订单退款处理、促销活动生成等
  • 用户管理,包括用户控制、冻结、解锁等
  • 权限管理,整个网站的权限控制,采用JWT鉴权方案,对用户及API进行权限控制
  • 统计,各种数据的统计分析展示
  • 后台系统会采用前后端分离开发,而且整个后台管理系统会使用Vue.js框架搭建出单页应用(SPA)

前台门户:

  • 搜索商品
  • 加入购物车
  • 下单
  • 评价商品等等
  • 前台系统我们会使用Nuxt结合Vue完成页面开发。出于SEO优化的考虑,我们将不采用单页应用


无论是前台还是后台系统,都共享相同的微服务集群,包括:

  • 商品微服务:商品及商品分类、品牌、库存等的服务
  • 搜索微服务:实现搜索功能
  • 订单微服务:实现订单相关
  • 购物车微服务:实现购物车相关功能
  • 用户中心:用户的登录注册等功能
  • 认证中心:用户权限及服务权限认证
  • Eureka注册中心
  • Zuul网关服务
  • Spring Cloud Config配置中心

技术选型

前端技术:

  • 基础的HTML、CSS、JavaScript(基于ES6标准)
  • Vue.js 2.0以及基于Vue的UI框架:Vuetify
  • 前端构建工具:WebPack
  • 前端安装包工具:NPM
  • Vue脚手架:Vue-cli
  • Vue路由:vue-router
  • ajax框架:axios
  • 基于Vue的富文本框架:quill-editor

后端技术:

  • 基础的SpringMVC、Spring 5.0和MyBatis3
  • Spring Boot 2.0.1版本
  • Spring Cloud 最新版 Finchley.RC1
  • Redis-4.0
  • RabbitMQ-3.4
  • Elasticsearch-5.6.8
  • nginx-1.10.2
  • FastDFS - 5.0.8
  • MyCat
  • Thymeleaf
  • JWT

技术解读

  • 利用Node.js及Vue.js技术栈,实现前后端分离开发
  • 利用SpringCloud技术栈,实现真正的微服务实战开发,并且是基于SpringBoot2.0和SpringCloud最新版本Finchley.RC1实现,业内领先。

  • 贴近真实的电商数据库设计,解决全品类电商的SPU和SKU管理问题
  • 基于FastDFS解决大数据量的分布式文件存储问题
  • 基于Elasticsearch高级聚合功能,实现商品的智能过滤搜索
  • 基于Elasticsearch高级聚合功能,实现销售业务的复杂统计及报表输出
  • 基于LocalStorage实现离线客户端购物车,减轻服务端压力
  • 基于JWT技术及RSA非对称加密实现真正无状态的单点登录
  • 结合JWT和RSA非对称加密,自定义Feign过滤器实现自动化服务间鉴权,解决服务对外暴露的安全问题
  • 基于阿里大于实现SMS功能,解决电商短信通知问题
  • 基于RabbitMQ实现可靠消息服务,解决服务间通信问题
  • 基于RabbitMQ实现可靠消息服务,解决分布式事务问题
  • 使用微信SDK实现微信扫码支付,符合主流付款方式
  • 基于Redis搭建高可用集群,实现可靠缓存服务即热点数据保存。redis持久化,集群,哨兵,主从,缓存击穿,热点key
  • 基于Redis和Mq来应对高可用高并发的秒杀场景
  • 基于MyCat实现数据库的读写分离和分库分表
  • 发视频基于Thymeleaf实现页面模板和静态化,提高页面响应速度和并发能力
  • 基于Nginx实现初步的请求负载均衡和请求限流


    本周热播