V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
gvison
V2EX  ›  Go 编程语言

在本地快速构建微服务集群(秒杀抢购和订单功能)来验证测试,个人感觉使用 dtm 来解决分布式事务还是挺优雅的,而且使用也比较简单。

  •  
  •   gvison · 15 小时 0 分钟前 · 396 次点击

    这是验证秒杀抢购和订单功能的 8 个服务框架图:

    eshop-framework

    服务 协议 HTTP 端口 gRPC 端口
    eshop_gw 内聚 api 网关服务 HTTP 8080 -
    user 用户服务 HTTP, gRPC 30080 30082
    product 产品服务 HTTP, gRPC 30180 30182
    order 订单服务 HTTP, gRPC 30280 30282
    stock 库存服务 HTTP, gRPC 30380 30382
    coupon 优惠券服务 HTTP, gRPC 30480 30482
    pay 支付服务 HTTP, gRPC 30580 30582
    flashSale 秒杀抢购服务 HTTP, gRPC 30680 30682

    使用负载测试工具 k6 分别对秒杀抢购 api提交订单 api进行压测,验证最终的数据一致性正确。压测结果与机器配置、网络环境、数据库配置等因素有关,这里不展示压测数据了。

    这是 8 个微服务的源码和从 0 开始搭建服务的文档说明

    注:源码的 2 个目录下代码基本一样,只是代码组织结构稍有不同,一个是微服务多仓库(multi-repo)代码组织结构,另一个是微服务单仓库(mono-repo)代码组织结构,8 个服务代码是生成的,然后按照生成的示例模板编写具体的业务逻辑代码。

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   6040 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 06:18 · PVG 14:18 · LAX 23:18 · JFK 02:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.