山西电商微服务架构模式(微服务电商项目)

大家好,田哥

之前,有很多人找我聊说:自己没有实际项目经验,面试的时候心里都很发慌。

于是,ta来了,名字咱们就叫他:快购商城

项目介绍

本项目命名为快购商城,分为两个端:用户端和商家端。

前台商城系统(用户端):包含首页门户、商品分类、新品上线、首页轮播、商品推荐、商品搜索、商品展示、购物车、订单结算、订单流程、提醒发货、订单取消、个人订单管理、会员中心、个人积分、帮助中心等。

商家管理系统(商家端):包含数据面板、轮播图管理、商品管理、订单管理、会员管理、积分管理、分类管理、订单提醒处理等。

山西电商微服务架构模式(微服务电商项目)(1)

功能会逐步优化和完善,本项目现在是构建了第二个版本。第一个版本是单体架构,关于单体项目这里就不少了。

技术栈

项目中运用到的技术栈:

  • Spring Boot:构建项目基础
  • Dubbo:服务治理和调用
  • Zookeeper:注册中心、分布式锁
  • MyBatis:数据库持久化
  • thymeleaf:前端渲染引擎
  • Redis:缓存、分布式锁、排行榜等
  • MySQL:数据存储
  • Rabbitmq:消息队列异步化、解耦
  • Seata:分布式事务
  • OSS:图片存储

开发工具:

  • IDEA
  • JDK1.8
  • Navicat for MySQL
  • Typora 文档编写
  • ZooInspector zk看客户端
数据库表

整个项目目前共有10张表(后面肯定会继续扩展的,所以表也会不断增多的):

  • tb_mall_admin_user 管理员表
  • tb_mall_carousel首页轮播商品表
  • tb_mall_goods_category 物品分类表
  • tb_mall_goods_info 物品详情表
  • tb_mall_index_config 首页配置表
  • tb_mall_order订单表
  • tb_mall_order_item 订单详情表
  • tb_mall_shopping_cart_item 购物车
  • tb_mall_user 用户表
  • tb_user_points 用户积分表
  • tb_login_log用户登录日志表
  • tb_order_remind提醒商家发货
项目结构介绍

山西电商微服务架构模式(微服务电商项目)(2)

happy-shopping-v2 模块介绍mall-web用户端展示项目

山西电商微服务架构模式(微服务电商项目)(3)

由于本项目不是前后端分离,前端渲染使用的是Thymeleaf,所以就会存在这么一个前端web服务,也可以当做是一个网关系统,不做具体业务,只是调用服务,数组整合然后展示。

mall-admin商家端展示项目

山西电商微服务架构模式(微服务电商项目)(4)

同mall-web系统类似,这里就不再赘述了。

mall-goods商品服务

山西电商微服务架构模式(微服务电商项目)(5)

商品服务包含以下内容:

  • 首页展示的轮播图
  • 商品种类
  • 首页配置展示
  • 商品信息

以Dubbo服务形式供外部调用。

mall-order订单服务

山西电商微服务架构模式(微服务电商项目)(6)

订单服务包含以下内容:

  • 订单
  • 订单详情
  • 购物车
  • 提醒商家

以Dubbo服务形式供外部调用。

mall-job定时任务服务

定时任务规划内容:

  • 定时查询支付单状态
  • 定时扫描订单超时未支付:用户订单提交了,但已超过应支付时间
  • 购物车商品下架:用户已加入购物车的商品下架,对应购物车商品也失效。

定时任务处理相关,项目以单独Spring Boot项目存在

mall-mq消息队列服务

山西电商微服务架构模式(微服务电商项目)(7)

消息队列项目包含以下内容:

  • 登录日志记录:用户每次登录进行日志记录
  • 购物车数量更新:每次加入购物车、订单提交等都应该更新购物车数量。
  • .....

以单独Spring Boot项目存在

mall-common公共服务

山西电商微服务架构模式(微服务电商项目)(8)

公共服务暂时还没实现具体功能,目前只是做一个统一工具类,然后其他服务就可以引用该jar包了。

后期可能会做一些服务,比如:分布式生成ID

目前就是一个单独的jar包,后期规划成Dubbo服务供外部系统调用。

mall-user用户服务

山西电商微服务架构模式(微服务电商项目)(9)

用户服务主要包含以下内容:

  • 用户信息
  • 商家信息
  • 用户积分

该服务以Dubbo服务供外部系统调用

系统功能点用户端功能点
  • 首页商品展示
  • 首页商品搜索
  • 商品详情
  • 注册
  • 登录
  • 退出
  • 添加到购物车
  • 查看购物车
  • 提交订单
  • 订单支付
  • 取消订单
  • 我的订单列表
  • 我的积分
  • 提醒发货
后台管理端功能点
  • 商品添加
  • 商品修改
  • 商品下架
  • 商品上架
  • 首页轮播图配置
  • 首页热销商品配置
  • 首页新品上线配置
  • 首页推送商品配置
  • 用户管理
  • 商品分类管理
  • 禁用
  • 解除禁用
  • 订单修改
  • 订单查询
  • 配货完成
  • 出库
  • 关闭订单
  • 积分管理
  • 消息管理
  • 修改密码
  • 退出

暂时想到这些,后面想到了继续完善。

项目收获

通过上面这个项目,你将可以收获如下技能包:

  • 分布式锁在项目中如何用
  • 线程池在项目中如何使用
  • 缓存如何在项目使用
  • 如何防止缓存穿透
  • 分布式session如何处理
  • 分布式事务在项目中如何运用
  • 如何利用Spring Boot Dubbo Zookeeper MyBatis MySQL Redis Rabbitmq构建一个微服务架构
  • ......

好吧,就这么多了。

我会把每个功能是怎么实现的,都整理出来,调用逻辑流程图等,最后都以文档形式呈现给大家。

欢迎大家点赞、转发

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页