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

简介: 创业失败,但技术沉淀值得复盘。基于SpringCloud Alibaba的微服务架构,围绕“团”与“提货点”核心业务,拆分出group-service等关键服务,采用“本地消息表+RocketMQ”实现分布式事务最终一致性,结合Redis Lua、两级缓存应对高并发。技术为业务服务,边界由业务变化频率决定。

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

image.png

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

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

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

最终我们的服务划分是:

  • 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让我们能快速迭代运营功能,而不影响核心交易链路。

相关文章
|
NoSQL 安全 Java
SpringBoot系列(2)整合MongoDB实现增删改查(完整案例)
自己本科时候一直使用的是Mysql,目前的课题组使用的是MongoDB,因此就花了一部分时间整理了一下,实现springboot与MongoDB的整合,并且实现基本的增删改查操作,从头到尾给出一个完整的案例。
1543 0
SpringBoot系列(2)整合MongoDB实现增删改查(完整案例)
|
机器学习/深度学习 搜索推荐 算法
基于机器学习的用户行为分析与个性化推荐系统
传统的用户行为分析和推荐系统常常受限于规则的刻板和模型的简单,无法准确捕捉用户的个性化需求。本文基于机器学习技术,探讨了一种更加灵活、精准的用户行为分析与个性化推荐系统设计方法,通过深度学习模型结合大数据分析,实现了对用户行为的更细致把握和更个性化的推荐服务。
|
7月前
|
机器学习/深度学习 算法 安全
近端策略优化算法PPO的核心概念和PyTorch实现详解
近端策略优化(PPO)是强化学习中的关键算法,因其在复杂任务中的稳定表现而广泛应用。本文详解PPO核心原理,并提供基于PyTorch的完整实现方案,涵盖环境交互、优势计算与策略更新裁剪机制。通过Lunar Lander环境演示训练流程,帮助读者掌握算法精髓。
835 54
|
5月前
|
监控 供应链 数据挖掘
京东平台 API:功能解析与典型应用场景
京东开放平台API涵盖商品、订单、库存、物流等核心功能,支持开发者与商家实现系统对接与数据协同。广泛应用于比价监控、多平台库存同步、ERP集成、数据分析等场景,助力企业提升运营效率,构建电商生态应用。
230 0
|
8月前
|
Apache 开发工具 数据格式
OpenAI 重返开源!gpt-oss系列社区推理、微调实战教程到!
时隔N年,OpenAI开放模型权重啦!欢迎使用gpt-oss 系列,专为强大的推理、代理任务和多用途开发场景设计。
1905 0
|
Python
Pandas 安装
10月更文挑战第26天
458 59
Pandas 安装
|
前端开发 JavaScript API
前端开发的秘密武器:这些工具让你轻松应对各种复杂动画效果!
【10月更文挑战第30天】前端开发中,动画效果为页面增添了无限生机。CSS3的@keyframes规则和JavaScript动画库如GSAP、Anime.js等,使开发者能轻松实现从简单到复杂的动画效果。掌握动画原理和设计原则,结合工具和库,可以创造出既美观又实用的动画,提升用户体验。
333 4
|
Rust 安全 数据挖掘
【颠覆常规】Rust科学计算革命:掌握数值分析与数据处理的全新利器,让你的工作事半功倍!
【8月更文挑战第31天】Rust语言凭借其出色的内存安全和高性能特性,在科学计算领域逐渐崭露头角。本文通过具体代码示例展示了Rust在数值计算与数据分析中的应用,包括矩阵乘法、统计分析及线性方程组求解。通过安装Rust并引入`ndarray`、`nalgebra`和`statrs`等库,读者可以轻松实现各类科学计算任务。Rust在科学计算领域的潜力巨大,未来可期。
1030 1
|
Linux Android开发 iOS开发
Windows平台RTSP|RTMP播放器如何实现实时录像功能
Windows平台RTSP、RTMP播放器实时录像接口设计,实际上,除了Windows平台,我们Linux、Android、iOS平台也是一样的设计,单纯的录像模块,如果做的全面,也不是一两个接口可以搞定的
484 1
|
SQL 缓存 前端开发
PHP性能优化实战:从代码到服务器的全方位攻略
【7月更文挑战第30天】在Web开发的世界里,PHP以其灵活性和易用性赢得了广泛的赞誉。然而,随着应用规模的扩大,性能问题逐渐浮现。本文将深入探讨PHP的性能优化策略,不仅涉及代码层面的精细调整,还包括服务器配置的优化技巧。我们将一起探索如何通过减少资源消耗、优化数据库交互以及利用缓存技术来提升PHP应用的性能表现。无论你是PHP新手还是资深开发者,这篇文章都将为你提供实用的优化建议,帮助你打造更快、更稳定的PHP应用。
316 4