news 2026/2/4 23:12:42

拆解基于SpringCloud社区团购项目:微服务划分与分布式事务实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
拆解基于SpringCloud社区团购项目:微服务划分与分布式事务实战

去年和朋友创业搞社区团购,惨淡收场,但技术架构沉淀了下来。这套基于SpringCloud Alibaba的微服务方案,经历过晚高峰的并发考验,今天拿出来复盘一下,重点聊聊我们当时如何划分服务,以及怎么搞定最头疼的分布式事务问题。

创业失败了,但代码是无辜的。当时我们几个技术合伙人,对微服务摩拳擦掌,觉得不用微服务都不好意思叫互联网项目。现在看,有些设计过度了,但也有不少值得坚持的地方。

一、微服务怎么拆?我们走过的弯路

最初我们按标准电商维度拆:用户、商品、订单、支付、库存。跑起来就出问题了。社区团购有个核心特征:“今日下单,明日自提”,所有业务都围绕“团”和“提货点”展开。

最终我们的服务划分是:

  • user-service (用户服务):基础,不说了。

  • product-service (商品服务):特别注意,商品价格和库存是按“团”维度管理的。同一个苹果,A小区团和B小区团价格、库存独立。

  • group-service (核心):这是我们的业务中台,管理“开团”、“参团”、“成团”状态,以及“提货点”信息。所有其他服务都重度依赖它。

  • order-service (订单服务):生成订单、状态流转。

  • inventory-service (库存服务)最复杂的服务之一。要处理下单预扣、支付后真实扣减、次日未提货自动返还、团长手动核销等一系列操作。我们把它独立出来,用Redis+Lua脚本保证原子性。

  • payment-service (支付服务):对接微信支付,成功后发消息。

  • delivery-service (核销/履约服务):处理团长扫码核销。

  • operation-service (运营后台):供内部使用。

教训:别为了拆而拆。“团”这个强业务概念,必须有一个核心服务来承载和协调,它就是group-service

二、分布式事务:跨服务下单的最终一致性方案

用户下单,涉及group-service(校验团状态)、inventory-service(扣库存)、order-service(生成订单)。怎么保证要么一起成功,要么一起失败?

我们放弃了Seata的AT模式(性能和维护成本考虑),采用了“本地消息表+最终一致性”,这是当时我们小团队最能把握的方案。

  1. 下单入口(order-service):在一个本地事务中,①生成“待支付”订单,②向本地消息表插入一条“扣库存”消息。事务保证这两步原子性。

  2. 定时任务扫描消息表,将消息通过RocketMQ发送出去。

  3. inventory-service:消费消息,执行预扣库存。如果失败(比如库存不足),则回发一条“扣库存失败”消息。

  4. order-service:消费“扣库存失败”消息,将订单状态改为“无效”。

同时,我们还有个“兜底对账”的Job,每小时跑一次,对比订单状态和库存流水,对状态不一致的进行补偿或告警。

三、高并发场景下的应对

晚高峰抢菜:核心是读多写少

  • :扣库存用Redis Lua,扛住瞬时压力。

  • :商品详情、团信息,全部上Redis缓存。注意,团状态(是否已成团)这种高频变化的数据,我们用了Redis Hash + 本地缓存(Caffeine)两级缓存,本地缓存设短时间(如2秒),极大减轻Redis压力。

  • 网关:用Spring Cloud Gateway做统一限流和熔断,特别是对“查询团长今日订单”这类接口。

四、复盘与反思

如果用现在的眼光看,inventory-servicegroup-service耦合有点紧,部分逻辑可以下沉为领域能力。但整体架构经受住了考验。微服务拆分的边界不是技术,而是业务能力与变更频率。社区团购的业务变化像风一样快,独立的operation-service让我们能快速迭代运营功能,而不影响核心交易链路。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/2 23:26:16

拓扑变换让机器人抓得又稳、又柔、又灵活

你是否见过这样的矛盾场景:工厂机器人能轻松举起百公斤重物,却会在抓取鸡蛋时瞬间将其捏碎;柔性机械抓手能温柔托起玻璃制品,面对重载时却力不从心;传统机械臂在规整环境中得心应手,遇到不规则物体或复杂空…

作者头像 李华
网站建设 2026/2/4 4:25:09

Hadoop大数据平台在中国AI时代的后续发展趋势研究

P(类Cloudera CDP 7.3 404版华为Kunpeng版) 摘要随着人工智能(AI)技术的迅猛发展和国家“数字中国”战略的深入推进,中国大数据产业正经历从规模扩张向智能驱动的深刻转型。作为大数据基础设施的核心组成部分&#xff…

作者头像 李华
网站建设 2026/2/2 19:11:10

从同步耦合到异步解耦:消息中间件如何重塑系统间的通信范式?

当成百上千的服务需要相互协作时,它们之间的通信模式变得至关重要。如果服务间采用紧密耦合的同步调用,一个服务的延迟或故障,就可能引发连锁反应,导致系统性的“雪崩”。消息中间件正是为了打破这种刚性依赖而生。它在服务之间建…

作者头像 李华
网站建设 2026/2/2 23:24:13

打卡信奥刷题(2534)用C++实现信奥 P2039 [AHOI2009] 跳棋

P2039 [AHOI2009] 跳棋 题目描述 在一个 111 行 NNN 列(NNN 是奇数)的棋盘上,有 KKK 个格子是红色的。这种情况下,你有一个跳棋在最左端的格子上。你的目标是将它移动到最右边的格子,在开始移动之间,你可以…

作者头像 李华
网站建设 2026/2/2 19:35:26

微服务链路追踪环境搭建终极指南:Docker一键部署全栈方案

微服务链路追踪环境搭建终极指南:Docker一键部署全栈方案 【免费下载链接】opentelemetry-collector OpenTelemetry Collector 项目地址: https://gitcode.com/GitHub_Trending/op/opentelemetry-collector 还在为分布式系统中的调用链追踪头疼吗&#xff1f…

作者头像 李华
网站建设 2026/2/3 0:31:57

Feather图标库完整使用指南:从入门到精通

Feather图标库完整使用指南:从入门到精通 【免费下载链接】feather 项目地址: https://gitcode.com/gh_mirrors/fea/feather 在开发现代Web应用时,图标的使用无处不在。你是否曾经遇到过这样的困扰:项目中的图标风格不统一、图标文件…

作者头像 李华