1 Star 1 Fork 5.9K

hahah / onemall

forked from 芋道源码 / yudao-cloud 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

[toc]

前言

基于微服务的思想,构建在 B2C 电商场景下的项目实战。

  • 「Talk is cheap. Show me the code」(屁话少说,放码过来)

    我们看过很多技术文章,却依然不知道微服务该咋整。

  • 整体的功能如下图:功能图

    功能图,和实际后端模块拆分,并不是绝对对应。

  • 交流群:传送门

    一起交流,Get 知识。

  • 我们迫切希望更多的参与进来,可以加入「交流群」,一起骚聊。

演示

H5 商城

体验传送门

TODO 此处应有一个演示的装逼 GIF 图。

管理后台

体验传送门

TODO 暂时不提供管理后台的账号密码,等后面提供。

TODO 此处应有一个演示的装逼 GIF 图。

TODO

提供其他演示环境。例如说 skywalking、sentinel 等等。

技术

搭建环境

搭建调试环境

架构图

TODO 此处应有一个架构图的装逼 JPG 图。

项目结构

模块 名称 端口
admin-web 【前端】管理后台 HTTP 8080
mobile-web 【前端】商城 H5 HTTP 8000
admin-application 管理员 HTTP 服务 HTTP 18083
user-application 用户 HTTP 服务 HTTP 18082
product-application 商品 HTTP 服务 HTTP 18081
pay-application 支付 HTTP 服务 HTTP 18084
promotion-application 促销 HTTP 服务 HTTP 18085
search-application 搜索 HTTP 服务 HTTP 18086
order-application 订单 HTTP 服务 HTTP 18088

后端项目,目前的项目结构如下:

[-] xxx
  ├──[-] xxx-application // 提供对外 HTTP API 。
  ├──[-] xxx-service-api // 提供 Dubbo 服务 API 。
  ├──[-] xxx-service-impl // 提供 Dubbo 服务 Service 实现。

考虑到大多数公司,无需拆分的特别细,并且过多 JVM 带来的服务器成本。所以目前的设定是:

  • xxx-service-impl 内嵌在 xxx-application 中运行。
  • MQ 消费者、定时器执行器,内嵌在 xxx-service-impl 中运行。

也就是说,一个 xxx-application 启动后,该模块就完整启动了。

技术栈

后端

框架 说明 版本
Spring Boot 应用开发框架 2.1.4
MySQL 数据库服务器 5.6
MyBatis 数据持久层框架 3.5.0
Redis key-value 数据库 暂未引入,等压测后,部分模块
Redisson Redis 客户端 暂未引入,等压测后,部分模块
Elasticsearch 分布式搜索引擎 6.7.1
Dubbo 分布式 RPC 服务框架 2.7.1
RocketMQ 消息中间件 4.3.2
SkyWalking 分布式应用追踪系统 6.0.0
Zookeeper 分布式系统协调 3.4.9 作为注册中心
XXL-Job 分布式任务调度平台 2.0.1

未来考虑引入

  • 配置中心 Nacos
  • 服务保障 Sentinel
  • 分布式事务 Seata
  • 数据库连接池 Druid
  • 网关 Soul

前端

商城 H5 和管理后台,分别采用了 Vue 和 React ,基于其适合的场景考虑。具体的,可以看看 《为什么 React 比 Vue 更适合大型应用?》 的讨论。

商城 H5

框架 说明 版本
Vue JavaScript 框架 2.5.17
Vant Vue UI 组件库 3.13.0

管理后台

框架 说明 版本
React JavaScript 框架 16.7.0
Ant Design React UI 组件库 3.13.0

其它

  • Jenkins 持续集成
  • Nginx 服务器
  • Docker 容器
  • Nginx

某种结尾

目前成员

  • 小范
  • 芋艿

空文件

简介

基于微服务的思想,构建在 B2C 电商场景下的项目实战。 核心技术栈,是 Spring Boot + Dubbo 。 未来,会重构成 Spring Cloud Alibaba 。 展开 收起
Java
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/chenchuxu/onemall.git
git@gitee.com:chenchuxu/onemall.git
chenchuxu
onemall
onemall
master

搜索帮助