一、微服务简介
微服务,或简称MSA,是将复杂的应用程序分解为一系列小而独立的功能单元的方法。每个功能单元犹如一个专业团队的成员,专注于执行特定任务。这些微服务之间通过API层或网关进行通信。以电子商务系统为例,一个微服务可能负责用户身份验证,另一个负责库存管理,再一个处理订单处理。每个微服务都有明确的职责,可以独立运行,这种细粒度设计使得扩展和维护更加高效。
单体应用与微服务架构区别:

在传统单体应用中,所有功能模块都在一个工程中编码、部署,即使是集群部署,也只是单体应用的水平复制。

在微服务架构的项目中,每个应用会按照领域模型划分进行业务、功能聚合,由此拆分后聚合的应用往往:模型高度统一、职责清晰且收敛、应用与应用(领域与领域)之间边界清晰,并且提升了每个应用的独立性、扩展性。
二、mall-swarm
mall-swarm项目简介:README.md · macro/mall-swarm - Gitee.com(内容如下)
友情提示
快速体验项目:在线访问地址 。
全套学习教程:《mall学习教程》 。
Spring Cloud全套教程:《SpringCloud学习教程》 。
专属学习路线:学习不走弯路,整理了套非常不错的《mall专属学习路线》 。
项目交流:想要加群交流项目的朋友,可以加入mall项目交流群 。
项目介绍
mall-swarm是一套微服务商城系统,采用了 Spring Cloud 2021 & Alibaba、Spring Boot 2.7、Oauth2、MyBatis、Elasticsearch、Docker、Kubernetes等核心技术,同时提供了基于Vue的管理后台方便快速搭建系统。mall-swarm在电商业务的基础集成了注册中心、配置中心、监控中心、网关等系统功能。文档齐全,附带全套Spring Cloud教程。
系统架构图

组织结构
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 -- 配置中心存储的配置
项目文档
-
项目文档
mall系列教程:项目主页 | mall学习教程 -
配套
Spring Cloud系列教程:GitHub - macrozheng/springcloud-learning: 一套涵盖大部分核心组件使用的Spring Cloud教程,包括Spring Cloud Alibaba及分布式事务Seata,基于Spring Cloud Greenwich及SpringBoot 2.1.7。篇篇精华,涵盖大部分应用场景。
项目演示
-
后台管理系统: mall-admin-web
技术选型
后端技术
前端技术
| 技术 | 说明 | 官网 |
|---|---|---|
| Vue | 前端框架 | Vue.js - The Progressive JavaScript Framework | Vue.js |
| Vue-router | 路由框架 | Vue Router | The official Router for Vue.js |
| Vuex | 全局状态管理框架 | What is Vuex? | Vuex |
| Element | 前端UI框架 | Element - The world's most popular Vue UI framework |
| Axios | 前端HTTP框架 | GitHub - axios/axios: Promise based HTTP client for the browser and node.js |
| v-charts | 基于Echarts的图表框架 | v-charts |
环境搭建
开发环境
| 工具 | 版本号 | 下载 |
|---|---|---|
| JDK | 1.8 | Java Downloads | Oracle |
| Mysql | 5.7 | MySQL |
| Redis | 7.0 | Download | Redis |
| Elasticsearch | 7.17.3 | Download Elasticsearch | Elastic |
| Kibana | 7.17.3 | Download Kibana Free | Get Started Now | Elastic |
| Logstash | 7.17.3 | Download Logstash Free | Get Started Now | Elastic |
| MongoDb | 5.0 | Try MongoDB Atlas Products | MongoDB |
| RabbitMq | 3.10.5 | Downloading and Installing RabbitMQ — RabbitMQ |
| nginx | 1.22 | nginx: download |
搭建步骤
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



1368

被折叠的 条评论
为什么被折叠?



