Home

Awesome

Stargazers over time

Stargazers over time

QuickStart

基于SpringCloud体系实现,简单购物流程实现,满足基本功能:注册、登录、商品列表展示、商品详情展示、订单创建、详情查看、订单支付、库存更新等等。

每个业务服务采用独立的MYSQL数据库,初期考虑用到如下组件:

  1. 服务注册、发现: eureka
  2. 配置管理:spring config , spring security
  3. 集群容错: hystrix
  4. API网关: zuul
  5. 服务负载:feign+ribbon
  6. api文档输出:swagger2
  7. 代码简化:lombok
  8. 消息队列:rabbitmq
  9. 分布式锁: redis (待实现)
  10. 链路跟踪:spring cloud sletuh ->zipkin
  11. 安全认证:oauth2/JWT(通过JWT轻量级的实现)
  12. 服务监控:spring-boot-admin

各模块介绍

模块名称端口简介
admin-server9002服务监控中心,监控所有服务模块
conf-server9004分布式配置中心,结合spring-security/rabbitmq同时使用
eureka-server9003服务注册中心,提供服务注册、发现功能
sleuth-server9001SpringCloud实现的一种分布式追踪解决方案,兼容Zipkin
zuul-server9005API网关模块
account-service8080用户服务,提供注册、登录、地址等服务
product-service8081商品服务,提供商品列表、详情、库存更新等服务
payment-service8082支付服务,支付记录
order-service8083订单服务,提供订单创建、详情、状态变更
msg-service8084消息处理服务
front-app        8088  前端服务,结合swagger2提供API管理(有小问题,swagger页面无法点击单个接口,可通过展开功能打开,待解决)

快速上手

相关测试

1、启动基础eureka/config两个服务后,直接启动front-app服务,通过swagger测试商品列表或详情功能来测试hystrix的功能
1.1、启动hystrix-dashboard服务,输入监控地址http://localhost:8088/hystrix.stream可以查看监控视图
2、输入http://localhost:9005/account-service/acc/login?phone=123123&password=123123查看返回结果

关注公众号,获取更多内容

image

个人主页:https://backkoms.github.io

基于SpringBoot+Dubbo微服务开发实战基础框架

github:https://github.com/backkoms/web-service-demo

github:https://github.com/backkoms/web-api-demo

我的知识星球,内容:个人心得体会分享(阅读、写作、职业规划、职业困惑、个人成长、技术提升)、问题提问

个人微信,欢迎骚扰

微服务开发实战专栏(SpringCloud、SpringCloudAlibaba、Apache Dubbo)

基于商场停车收费场景的微服务开发实战专栏地址:https://xiaozhuanlan.com/msa-practice