商城是基于Spring Cloud、Nacos、Seata、Mysql、Redis、RocketMQ、canal、ElasticSearch、minio的微服务B2B2C电商商城系统,采用主流的互联网技术架构、全新的UI设计、支持集群部署、服务注册和发现以及拥有完整的订单流程等,代码完全开源,没有任何二次封装,是一个非常适合二次开发的电商平台系统。
商城致力于为中大型企业打造一个功能完整、易于维护的微服务B2B2C电商商城系统,采用主流微服务技术实现。后台管理系统包含平台管理,店铺管理、商品管理、订单管理、规格管理、权限管理、资源管理等模块。
因最近将项目的环境部署并运行了一下,通过阅读源码,发现是一个很完整的springcloud项目。现在通过笔记方式再次记录一下,学习其中的微服务架构设计和B2B2C电商商城系统的一些解决方案。
因官方源码使用的是jdk17,和自己平时用的jdk11和1.8有些区别,就将项目的jdk环境还原到了1.8版本
github:
https://github.com/cjy-chenjy/mall4cloud
fork自https://github.com/gz-yami/mall4cloud
gitee:
https://gitee.com/cjy7007/mall4cloud
fork自https://gitee.com/gz-yami/mall4cloud
从上述地址可以pull源码,且md文件中有具体的介绍,就不照搬了
github的文档中详细给了开发文档和环境搭建视频,且环境通过docker-compse比较方便。对于环境搭建做以下补充:
1、关于中间件使用的服务器:
服务器建议新开一个虚拟机,因项目的数据库和一些环境都是重新通过docker搭建,可能会和已使用过的端口冲突。配置建议内存4核6g以上,因为项目的中间件启动还是需要占用较多内存
或者使用一台云服务器,毕竟任何时候都可以连接。配置也需要至少选择2核4g,作者就是这样的一台服务器,但是启动一些中间件还是比较费劲。就像rocketMQ没有启动dashboard,es没有启动kibana等,只启动了一些主要服务。
2、docker-compse文件介绍
根据视频可以完整的将docker-compse环境搭建起来,对文档中的一些内容增加注释如下:
version: "3.5"
services:
mall4cloud-mysql:
image: mysql:8.0
container_name: mall4cloud-mysql
restart: always
environment:
- MYSQL_ROOT_PASSWORD=root # 设置MySQL的root用户密码
ports:
- 3306:3306 # 映射容器内部3306端口到宿主机的3306端口
volumes:
- ./mysql/data:/var/lib/mysql # 将宿主机的目录挂载到容器的/var/lib/mysql目录
- ./mysql/conf.d:/etc/mysql/conf.d # 将宿主机的目录挂载到容器的/etc/mysql/conf.d目录
- ./mysql/initdb:/docker-entrypoint-initdb.d # 将宿主机的目录挂载到容器的/docker-entrypoint-initdb.d目录
mall4cloud-minio:
image: minio/minio:RELEASE.2021-06-17T00-10-46Z
container_name: mall4cloud-minio
restart: always
command: server /data # 启动MinIO服务器并指定数据目录
ports:
- 9000:9000 # 映射容器内部9000端口到宿主机的9000端口
volumes:
- ./minio/data:/data # 将宿主机的目录挂载到容器的/data目录
environment:
- MINIO_ROOT_USER=admin # 设置MinIO的管理员用户名
- MINIO_ROOT_PASSWORD=admin123456 # 设置MinIO的管理员密码
mall4cloud-redis:
image: redis:6.2
container_name: mall4cloud-redis
restart: always
ports:
- 6379:6379 # 映射容器内部6379端口到宿主机的6379端口
mall4cloud-nacos:
image: nacos/nacos-server:v2.2.0-slim
container_name: mall4cloud-nacos
restart: always
depends_on:
- mall4cloud-mysql # 确保在启动前依赖于MySQL服务
ports:
- 8848:8848 # 映射容器内部8848端口到宿主机的8848端口
- 9848:9848
- 9849:9849
environment:
- JVM_XMS=256m # 配置JVM的最小内存分配
- JVM_XMX=256m # 配置JVM的最大内存分配
- MODE=standalone # 设置Nacos运行模式为独立模式
- PREFER_HOST_MODE=hostname
- SPRING_DATASOURCE_PLATFORM=mysql
- MYSQL_SERVICE_HOST=192.168.1.46 # MySQL数据库的主机地址
- MYSQL_SERVICE_DB_NAME=mall4cloud_nacos # Nacos使用的数据库名
- MYSQL_SERVICE_USER=root # 连接MySQL的用户名
- MYSQL_SERVICE_PASSWORD=root # 连接MySQL的密码
volumes:
- ./nacos/logs:/home/nacos/logs # 将宿主机的目录挂载到容器的日志目录
mall4cloud-seata:
image: seataio/seata-server:1.6.1
container_name: mall4cloud-seata
restart: always
depends_on:
- mall4cloud-mysql
- mall4cloud-nacos
ports:
- 8091:8091 # 映射容器内部8091端口到宿主机的8091端口
- 7091:7091
environment:
- SEATA_IP=192.168.1.46 # Seata服务器IP地址
volumes:
- ./seata/application.yml:/seata-server/resources/application.yml # 将宿主机的配置文件挂载到Seata容器
mall4cloud-elasticsearch:
image: elasticsearch:7.17.5
container_name: mall4cloud-elasticsearch
restart: always
ports:
- 9200:9200 # 映射容器内部9200端口到宿主机的9200端口
- 9300:9300
environment:
- discovery.type=single-node # 设置Elasticsearch为单节点模式
- ES_JAVA_OPTS=-Xms512m -Xmx512m # 配置JVM堆内存
volumes:
- ./elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml # 挂载配置文件
- ./elasticsearch/data:/usr/share/elasticsearch/data # 挂载数据目录
- ./elasticsearch/plugins:/usr/share/elasticsearch/plugins # 挂载插件目录
mall4cloud-kibana:
image: kibana:7.17.5
container_name: mall4cloud-kibana
restart: always
ports:
- 5601:5601 # 映射容器内部5601端口到宿主机的5601端口
links:
- mall4cloud-elasticsearch:elasticsearch # 与Elasticsearch容器建立链接
depends_on:
- mall4cloud-elasticsearch # 确保在启动前依赖于Elasticsearch
mall4cloud-canal:
image: canal/canal-server:v1.1.6
container_name: mall4cloud-canal
restart: always
ports:
- 11111:11111 # 映射容器内部11111端口到宿主机的11111端口
volumes:
- ./canal/conf/example:/home/admin/canal-server/conf/example # 挂载配置文件
- ./canal/conf/canal.properties:/home/admin/canal-server/conf/canal.properties # 挂载配置文件
- ./canal/logs:/home/admin/canal-server/logs # 挂载日志目录
mall4cloud-rocketmq-namesrv:
image: apache/rocketmq:4.9.4
container_name: mall4cloud-rocketmq-namesrv
restart: always
ports:
- 9876:9876 # 映射容器内部9876端口到宿主机的9876端口
volumes:
- ./rocketmq/namesrv/logs:/home/rocketmq/logs # 挂载日志目录
- ./rocketmq/namesrv/store:/home/rocketmq/store # 挂载存储目录
environment:
JAVA_OPT_EXT: "-Duser.home=/home/rocketmq -Xms512M -Xmx512M -Xmn128M" # 配置Java参数
command: ["sh","mqnamesrv"] # 启动命令
networks:
rocketmq:
aliases:
- mall4cloud-rocketmq-namesrv
mall4cloud-rocketmq-broker:
image: apache/rocketmq:4.9.4
container_name: mall4cloud-rocketmq-broker
restart: always
ports:
- 10909:10909 # 映射容器内部10909端口到宿主机的10909端口
- 10911:10911
volumes:
- ./rocketmq/broker/logs:/home/rocketmq/logs # 挂载日志目录
- ./rocketmq/broker/store:/home/rocketmq/store # 挂载存储目录
- ./rocketmq/broker/conf/broker.conf:/etc/rocketmq/broker.conf # 挂载配置文件
environment:
JAVA_OPT_EXT: "-Duser.home=/home/rocketmq -Xms512M -Xmx512M -Xmn128M -XX:-AssumeMP" # 配置Java参数
command: ["sh","mqbroker","-c","/etc/rocketmq/broker.conf","-n","mall4cloud-rocketmq-namesrv:9876","autoCreateTopicEnable=true"] # 启动命令
depends_on:
- mall4cloud-rocketmq-namesrv # 确保在启动前依赖于RocketMQ Namesrv
networks:
rocketmq:
aliases:
- mall4cloud-rocketmq-broker
mall4cloud-rocketmq-dashboard:
image: apacherocketmq/rocketmq-dashboard:1.0.0
container_name: mall4cloud-rocketmq-dashboard
restart: always
ports:
- 8180:8080 # 映射容器内部8080端口到宿主机的8180端口
environment:
JAVA_OPTS: "-Drocketmq.namesrv.addr=mall4cloud-rocketmq-namesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" # 配置Java参数
depends_on:
- mall4cloud-rocketmq-namesrv # 确保在启动前依赖于RocketMQ Namesrv
networks:
rocketmq:
aliases:
- mall4cloud-rocketmq-console
# 定义自定义网络
networks:
rocketmq:
name: rocketmq
driver: bridge
3、es的模板建立
如果使用es-head,则使用如下命令
http://127.0.0.1:9200/_template/product/
使用kibana的话根据视频正常建立即可
4、后端代码通过idea打开后没有services管理
正常来说,启动项目后右下角会提示是否要打开services窗口,点击同意即可,如果未提示,看这篇文章的解决方法
https://blog.csdn.net/weixin_45764765/article/details/124794766
看一下项目的父pom文件内容
①:指定项目的gav坐标
②:指定项目的模块依赖,可以看到有14个模块,后面一一介绍
③④:项目的具体配置,可以看到使用了jdk1.8版本,这个也要和maven的conf下的seeting.xml版本保持一致,且和idea的jdk环境保持一致,下图中打开的内容。
继续看下面的配置
①②③:springboot、springCloud、springCloudAlibaba三者的版本号,这个版本有具体的对应关系。如下图,具体版本详细对照:https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E
④可以修改版本的两个依赖
⑤一些依赖的版本管理,中间件的版本对照也可以看这个,就不一一列举了
https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E
①②③:元素是用于集中管理项目中所有依赖库的版本号的部分。但不会直接引入这些依赖。也就是这部分只是做gav坐标的管理。方便后续各个模块直接引入
①②:这里是表示这个spring-boot-configuration-processor是可选的,也是没有引入,如需引入需指定具体版本
③~⑥等后续:
这个可以直接参考视频运行即可