微服务商城系统——mall-swarm

一、微服务简介

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

单体应用与微服务架构区别:

微服务商城系统——mall-swarm_第1张图片

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

微服务商城系统——mall-swarm_第2张图片

        在微服务架构的项目中,每个应用会按照领域模型划分进行业务、功能聚合,由此拆分后聚合的应用往往:模型高度统一、职责清晰且收敛、应用与应用(领域与领域)之间边界清晰,并且提升了每个应用的独立性、扩展性。

二、mall-swarm

mall-swarm项目简介:README.md · macro/mall-swarm - Gitee.com(内容如下)

友情提示

  1. 快速体验项目:在线访问地址 。

  2. 全套学习教程:《mall学习教程》 。

  3. Spring Cloud全套教程:《SpringCloud学习教程》 。

  4. 专属学习路线:学习不走弯路,整理了套非常不错的《mall专属学习路线》 。

  5. 项目交流:想要加群交流项目的朋友,可以加入mall项目交流群 。

项目介绍

mall-swarm是一套微服务商城系统,采用了 Spring Cloud 2021 & Alibaba、Spring Boot 2.7、Oauth2、MyBatis、Elasticsearch、Docker、Kubernetes等核心技术,同时提供了基于Vue的管理后台方便快速搭建系统。mall-swarm在电商业务的基础集成了注册中心、配置中心、监控中心、网关等系统功能。文档齐全,附带全套Spring Cloud教程。

系统架构图

微服务商城系统——mall-swarm_第3张图片

组织结构

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

  • 移动端商城系统:https://www.macrozheng.com/app/mainpage.html

技术选型

后端技术
技术 说明 官网
Spring Cloud 微服务框架 Spring Cloud
Spring Cloud Alibaba 微服务框架 GitHub - alibaba/spring-cloud-alibaba: Spring Cloud Alibaba provides a one-stop solution for application development for the distributed solutions of Alibaba middleware.
Spring Boot 容器+MVC框架 Spring Boot
Spring Security Oauth2 认证和授权框架 Spring Security OAuth
MyBatis ORM框架 mybatis – MyBatis 3 | 简介
MyBatisGenerator 数据层代码生成 MyBatis Generator Core – Introduction to MyBatis Generator
PageHelper MyBatis物理分页插件 Mybatis_PageHelper: Mybatis分页插件
Knife4j 文档生产工具 GitHub - xiaoymin/swagger-bootstrap-ui: Knife4j is a set of Swagger2 and OpenAPI3 All-in-one enhancement solution
Elasticsearch 搜索引擎 GitHub - elastic/elasticsearch: Free and Open, Distributed, RESTful Search Engine
RabbitMq 消息队列 RabbitMQ: easy to use, flexible messaging and streaming — RabbitMQ
Redis 分布式缓存 Redis
MongoDb NoSql数据库 MongoDB: The Developer Data Platform | MongoDB
Docker 应用容器引擎 Docker: Accelerated Container Application Development
Druid 数据库连接池 GitHub - alibaba/druid: 阿里云计算平台DataWorks(https://help.aliyun.com/document_detail/137663.html) 团队出品,为监控而生的数据库连接池
OSS 对象存储 GitHub - aliyun/aliyun-oss-java-sdk: Aliyun OSS SDK for Java
MinIO 对象存储 GitHub - minio/minio: High Performance Object Storage for AI
JWT JWT登录支持 GitHub - jwtk/jjwt: Java JWT: JSON Web Token for Java and Android
LogStash 日志收集 GitHub - logfellow/logstash-logback-encoder: Logback JSON encoder and appenders
Lombok 简化对象封装工具 GitHub - projectlombok/lombok: Very spicy additions to the Java programming language.
Seata 全局事务管理框架 GitHub - seata/seata: :fire: Seata is an easy-to-use, high-performance, open source distributed transaction solution.
Portainer 可视化Docker容器管理 GitHub - portainer/portainer: Making Docker and Kubernetes management easy.
Jenkins 自动化部署工具 GitHub - jenkinsci/jenkins: Jenkins automation server
Kubernetes 应用容器管理平台 Kubernetes
前端技术
技术 说明 官网
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/

微服务商城系统——mall-swarm_第4张图片

  • 监控中心应用信息,访问地址:http://192.168.3.101:8101

微服务商城系统——mall-swarm_第5张图片

微服务商城系统——mall-swarm_第6张图片

微服务商城系统——mall-swarm_第7张图片

  • API文档信息,访问地址:http://192.168.3.101:8201

微服务商城系统——mall-swarm_第8张图片

  • 日志收集系统信息,访问地址:http://192.168.3.101:5601

微服务商城系统——mall-swarm_第9张图片

  • 可视化容器管理,访问地址:http://192.168.3.101:9000

微服务商城系统——mall-swarm_第10张图片

微服务商城系统——mall-swarm_第11张图片

你可能感兴趣的:(微服务,java,数据库)