本文介绍的项目是基于SpringCloud为服务化的系统架构实现。从微服务网关,微服务注册与发现,配置、熔断限流、监控、以及服务调用链路追踪等,以及容器化部署持续集成等一系列方案。

项目地址:https://github.com/macrozheng/mall 

mall

电商商城APP架构 网上商城架构_html

前言

mall项目致力于打造一个完整的电商系统,采用现阶段流行技术实现。

项目文档

项目介绍

mall项目是一套电商系统,包括前台商城系统及后台管理系统,基于SpringBoot+MyBatis实现,采用Docker容器化部署。前台商城系统包含首页门户、商品推荐、商品搜索、商品展示、购物车、订单流程、会员中心、客户服务、帮助中心等模块。后台管理系统包含商品管理、订单管理、会员管理、促销管理、运营管理、内容管理、统计报表、财务管理、权限管理、设置等模块。

项目演示

后台管理系统

前端项目mall-admin-web地址:https://github.com/macrozheng/mall-admin-web

项目演示地址: http://www.macrozheng.com/admin/index.html

电商商城APP架构 网上商城架构_html_02

前台商城系统

前端项目mall-app-web地址:敬请期待......

项目演示地址:http://www.macrozheng.com/app/index.html

电商商城APP架构 网上商城架构_html_03

组织结构

mall
├── mall-common -- 工具类及通用代码
├── mall-mbg -- MyBatisGenerator生成的数据库操作代码
├── mall-security -- SpringSecurity封装公用模块
├── mall-admin -- 后台商城管理系统接口
├── mall-search -- 基于Elasticsearch的商品搜索系统
├── mall-portal -- 前台商城系统接口
└── mall-demo -- 框架搭建时的测试代码

技术选型

后端技术

技术

说明

官网

SpringBoot

容器+MVC框架

https://spring.io/projects/spring-boot

SpringSecurity

认证和授权框架

https://spring.io/projects/spring-security

MyBatis

ORM框架

http://www.mybatis.org/mybatis-3/zh/index.html

MyBatisGenerator

数据层代码生成

http://www.mybatis.org/generator/index.html

PageHelper

MyBatis物理分页插件

Swagger-UI

文档生产工具

https://github.com/swagger-api/swagger-ui

Hibernator-Validator

验证框架

http://hibernate.org/validator

Elasticsearch

搜索引擎

https://github.com/elastic/elasticsearch

RabbitMQ

消息队列

https://www.rabbitmq.com/

Redis

分布式缓存

https://redis.io/

MongoDB

NoSql数据库

https://www.mongodb.com

Docker

应用容器引擎

https://www.docker.com

Druid

数据库连接池

https://github.com/alibaba/druid

OSS

对象存储

https://github.com/aliyun/aliyun-oss-java-sdk

MinIO

对象存储

https://github.com/minio/minio

JWT

JWT登录支持

https://github.com/jwtk/jjwt

LogStash

日志收集工具

https://github.com/logstash/logstash-logback-encoder

Lombok

简化对象封装工具

https://github.com/rzwitserloot/lombok

Jenkins

自动化部署工具

https://github.com/jenkinsci/jenkins

前端技术

技术

说明

官网

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/

Js-cookie

cookie管理工具

https://github.com/js-cookie/js-cookie

nprogress

进度条控件

https://github.com/rstacruz/nprogress

架构图

系统架构图

电商商城APP架构 网上商城架构_Docker_04

业务架构图

电商商城APP架构 网上商城架构_html_05

模块介绍

后台管理系统 mall-admin

前台商城系统 mall-portal

功能结构图-前台.jpg

开发进度

电商商城APP架构 网上商城架构_html_06

环境搭建

开发工具

工具

说明

官网

IDEA

开发IDE

https://www.jetbrains.com/idea/download

RedisDesktop

redis客户端连接工具

https://github.com/qishibo/AnotherRedisDesktopManager

Robomongo

mongo客户端连接工具

https://robomongo.org/download

SwitchHosts

本地host管理

https://oldj.github.io/SwitchHosts/

X-shell

Linux远程连接工具

http://www.netsarang.com/download/software.html

Navicat

数据库连接工具

http://www.formysql.com/xiazai.html

PowerDesigner

数据库设计工具

http://powerdesigner.de/

Axure

原型设计工具

https://www.axure.com/

MindMaster

思维导图设计工具

http://www.edrawsoft.cn/mindmaster

ScreenToGif

gif录制工具

https://www.screentogif.com/

ProcessOn

流程图绘制工具

https://www.processon.com/

PicPick

图片处理工具

https://picpick.app/zh/

Snipaste

屏幕截图工具

https://www.snipaste.com/

Postman

API接口调试工具

https://www.postman.com/

Typora

Markdown编辑器

https://typora.io/

开发环境

工具

版本号

下载

JDK

1.8

https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html

Mysql

5.7

https://www.mysql.com/

Redis

5.0

https://redis.io/download

MongoDB

4.2.5

https://www.mongodb.com/download-center

RabbitMQ

3.7.14

http://www.rabbitmq.com/download.html

Nginx

1.10

http://nginx.org/en/download.html

Elasticsearch

7.6.2

https://www.elastic.co/downloads/elasticsearch

Logstash

7.6.2

https://www.elastic.co/cn/downloads/logstash

Kibana

7.6.2

https://www.elastic.co/cn/downloads/kibana

搭建步骤

Windows环境部署

Docker环境部署

相关环境部署