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

一、微服务简介

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

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

图片

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

图片

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

二、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
├── 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 -- 配置中心存储的配置

项目文档

项目演示

技术选型

后端技术
技术说明官网
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
MyBatisORM框架mybatis – MyBatis 3 | 简介
MyBatisGenerator数据层代码生成MyBatis Generator Core – Introduction to MyBatis Generator
PageHelperMyBatis物理分页插件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
MongoDbNoSql数据库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
JWTJWT登录支持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

环境搭建

开发环境
工具版本号下载
JDK1.8Java Downloads | Oracle
Mysql5.7MySQL
Redis7.0Download | Redis
Elasticsearch7.17.3Download Elasticsearch | Elastic
Kibana7.17.3Download Kibana Free | Get Started Now | Elastic
Logstash7.17.3Download Logstash Free | Get Started Now | Elastic
MongoDb5.0Try MongoDB Atlas Products | MongoDB
RabbitMq3.10.5Downloading and Installing RabbitMQ — RabbitMQ
nginx1.22nginx: download
搭建步骤

Windows环境部署

Docker环境部署

Kubernetes环境部署

运行效果展示

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值