大家好,田哥
之前,有很多人找我聊说:自己没有实际项目经验,面试的时候心里都很发慌。
于是,ta来了,名字咱们就叫他:快购商城
本项目命名为快购商城,分为两个端:用户端
和商家端
。
前台商城系统(用户端):包含首页门户、商品分类、新品上线、首页轮播、商品推荐、商品搜索、商品展示、购物车、订单结算、订单流程、提醒发货、订单取消、个人订单管理、会员中心、个人积分、帮助中心等。
商家管理系统(商家端):包含数据面板、轮播图管理、商品管理、订单管理、会员管理、积分管理、分类管理、订单提醒处理等。
功能会逐步优化和完善,本项目现在是构建了第二个版本。第一个版本是单体架构,关于单体项目这里就不少了。
项目中运用到的技术栈:
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
提醒商家发货mall-web
用户端展示项目由于本项目不是前后端分离,前端渲染使用的是Thymeleaf
,所以就会存在这么一个前端web服务,也可以当做是一个网关系统,不做具体业务,只是调用服务,数组整合然后展示。
mall-admin
商家端展示项目同mall-web系统类似,这里就不再赘述了。
mall-goods
商品服务商品服务包含以下内容:
以Dubbo
服务形式供外部调用。
mall-order
订单服务订单服务包含以下内容:
以Dubbo
服务形式供外部调用。
mall-job
定时任务服务定时任务规划内容:
定时任务处理相关,项目以单独Spring Boot项目存在
mall-mq
消息队列服务消息队列项目包含以下内容:
以单独Spring Boot项目存在
mall-common
公共服务公共服务暂时还没实现具体功能,目前只是做一个统一工具类,然后其他服务就可以引用该jar包了。
后期可能会做一些服务,比如:分布式生成ID
目前就是一个单独的jar包,后期规划成Dubbo服务供外部系统调用。
mall-user
用户服务用户服务主要包含以下内容:
该服务以
Dubbo
服务供外部系统调用
暂时想到这些,后面想到了继续完善。
通过上面这个项目,你将可以收获如下技能包:
session
如何处理Spring Boot+Dubbo+Zookeeper+MyBatis+MySQL+Redis+Rabbitmq
构建一个微服务架构好吧,就这么多了。
我会把每个功能是怎么实现的,都整理出来,调用逻辑流程图等,最后都以文档形式呈现给大家。