mall-swarm
Introduction: mall-swarm 是一套微服务商城系统,采用了 Spring Cloud Hoxton & Alibaba、Spring Boot 2.3、Oauth2、MyBatis、Docker、Elasticsearch 等核心技术,同时提供了基于 Vue 的管理后台方便快速搭建系统。mall-swarm 在电商业务的基础集成了注册中心、配置中心、监控中心、网关等系统功能。文档齐全,附带全套 Spring Cloud 教程。
Tags:
友情提示
- 快速体验项目:在线访问地址 。
- 全套学习教程:《mall 学习教程》 。
- 视频教程(2023 最新版):《mall 视频教程》 。
- Spring Cloud 全套教程:《SpringCloud 学习教程》 。
- 项目交流:想要加群交流项目的朋友,可以加入mall 项目交流群 。
项目简介
mall-swarm
是一套微服务商城系统,采用了 Spring Cloud 2021 & Alibaba、Spring Boot 2.7、Oauth2、MyBatis、Elasticsearch、Docker、Kubernetes 等核心技术,同时提供了基于 Vue 的管理后台方便快速搭建系统。mall-swarm
在电商业务的基础集成了注册中心、配置中心、监控中心、网关等系统功能。文档齐全,附带全套 Spring Cloud 教程。
项目演示
后台管理系统
前端项目mall-admin-web
地址:https://github.com/macrozheng/mall-admin-web
项目演示地址: https://www.macrozheng.com/admin/index.html
前台商城系统
前端项目mall-app-web
地址:https://github.com/macrozheng/mall-app-web
项目演示地址(将浏览器切换为手机模式效果更佳):https://www.macrozheng.com/app/
项目架构
系统架构
业务架构
组织结构
mall
├── mall-common -- 工具类及通用代码模块
├── mall-mbg -- MyBatisGenerator 生成的数据库操作代码模块
├── mall-auth -- 基于 Spring Security Oauth2 的统一的认证中心
├── mall-gateway -- 基于 Spring Cloud Gateway 的微服务 API 网关服务
├── mall-monitor -- 基于 Spring Boot Admin 的微服务监控中心
├── mall-admin -- 后台管理系统服务
├── mall-search -- 基于 Elasticsearch 的商品搜索系统服务
├── mall-portal -- 移动端商城系统服务
├── mall-demo -- 微服务远程调用测试服务
└── config -- 配置中心存储的配置
技术选型
后端技术
前端技术
技术 | 说明 | 官网 |
---|---|---|
Vue | 前端框架 | https://vuejs.org/ |
Vue-router | 路由框架 | https://router.vuejs.org/ |
Vuex | 全局状态管理框架 | https://vuex.vuejs.org/ |
Element | 前端 UI 框架 | https://element.eleme.io/ |
Axios | 前端 HTTP 框架 | https://github.com/axios/axios |
v-charts | 基于 Echarts 的图表框架 | https://v-charts.js.org/ |
移动端技术
技术 | 说明 | 官网 |
---|---|---|
Vue | 核心前端框架 | https://vuejs.org |
Vuex | 全局状态管理框架 | https://vuex.vuejs.org |
uni-app | 移动端前端框架 | https://uniapp.dcloud.io |
mix-mall | 电商项目模板 | https://ext.dcloud.net.cn/plugin?id=200 |
luch-request | HTTP 请求框架 | https://github.com/lei-mu/luch-request |
环境搭建
开发环境
工具 | 版本号 | 下载 |
---|---|---|
JDK | 1.8 | https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html |
Mysql | 5.7 | https://www.mysql.com/ |
Redis | 7.0 | https://redis.io/download |
Elasticsearch | 7.17.3 | https://www.elastic.co/cn/downloads/elasticsearch |
Kibana | 7.17.3 | https://www.elastic.co/cn/downloads/kibana |
Logstash | 7.17.3 | https://www.elastic.co/cn/downloads/logstash |
MongoDb | 5.0 | https://www.mongodb.com/download-center |
RabbitMq | 3.10.5 | http://www.rabbitmq.com/download.html |
nginx | 1.22 | http://nginx.org/en/download.html |
搭建步骤
Windows 环境部署
- Windows 环境搭建请参考:mall-swarm 在 Windows 环境下的部署;
mall-admin-web
项目的安装及部署请参考:mall 前端项目的安装与部署;ELK
日志收集系统的搭建请参考:SpringBoot 应用整合 ELK 实现日志收集;- 使用 MinIO 存储文件请参考:前后端分离项目,如何优雅实现文件存储;
- 读写分离解决方案请参考:你还在代码里做读写分离么,试试这个中间件吧;
分布式事务
解决方案请参考:使用 Seata 彻底解决 Spring Cloud 中的分布式事务问题! 。
Docker 环境部署
- 使用虚拟机安装 CentOS7.6 请参考:虚拟机安装及使用 Linux,看这一篇就够了;
- Docker 环境的安装请参考:开发者必备 Docker 命令;
- 本项目 Docker 镜像构建请参考:使用 Maven 插件为 SpringBoot 应用构建 Docker 镜像;
- 本项目在 Docker 容器下的部署请参考:mall-swarm 在 Linux 环境下的部署(基于 Docker 容器);
- 本项目使用 Jenkins 自动化部署请参考:mall-swarm 使用 Jenkins 实现自动化部署 。
Kubernetes 环境部署
- 本项目使用 Kubernetes 部署请参考:mall-swarm 微服务项目在 K8S 下的实践!
运行效果展示
- 查看注册中心注册服务信息,访问地址:http://192.168.3.101:8848/nacos/
- 监控中心应用信息,访问地址:http://192.168.3.101:8101
- API 文档信息,访问地址:http://192.168.3.101:8201
- 日志收集系统信息,访问地址:http://192.168.3.101:5601
- 可视化容器管理,访问地址:http://192.168.3.101:9000
公众号
加微信群交流,关注公众号「macrozheng」,回复「加群」即可。
许可证
Copyright (c) 2018-2024 macrozheng