浅谈电商下单微服务流程

SpringCloud 微服务 主流程

  1. 所有微服务启动后把自己 IP + 端口注册到 Nacos。
  2. 前端请求统一接入 Gateway网关 → 请求进入网关后首先被 Sentinel 拦截处理,(IP黑白名单过滤、路由权限校验、网关全局限流。)
  3. 校验放行之后,网关Gateway 根据服务注册中心 Nacos/Eureka 的服务列表拉取服务实例,通过 LoadBalancer 选一台健康实例,自动做负载均衡转发。
  4. 业务微服务需要跨服务调用时,通过 OpenFeign 发起跨服务调用。Feign 底层依赖 LoadBalancer 按照轮询 / 随机规则 选一台健康实例。

++++(++++ ++++调用频繁超时 / 报错 → Sentinel 触发熔断++++ ++++,++++ ++++熔断后 Feign 直接走 Fallback 降级,不卡死线程++++ ++++,++++ ++++LoadBalancer 自带健康探测,自动剔除故障、宕机、失联的微服务实例,后续流量只分发到正常节点。++++ ++++)++++

电商下单实战应用

  1. 用户下单 → 2. 校验商品/价格 → 3. 扣减库存(Redis/DB) → 4. 创建订单 → 5. 订单状态流转(待支付 → 已支付 → 已发货) → 6. 超时未支付 → 自动取消订单 + 回滚库存

需要注意的坑:

1. 并发超卖

  • 必须用 Redis 分布式锁
  • 库存必须用 乐观锁

2. 重复下单

  • 接口必须做 幂等性(token / 唯一订单号)
  • 用户维度加锁

3. 订单创建了,库存没扣 / 库存扣了订单没创建

  • 必须用 Seata 分布式事务 保证原子性

4. 超时取消不准时

  • 必须用 消息队列延迟消息
  • 不要用定时任务(不准、性能差)

5. 远程调用异常

  • 必须用 Sentinel 熔断、降级、限流
  • 调用失败不能产生脏数据

6. 高并发流量冲击

  • 库存预热到 Redis
  • 下单接口限流
  • 使用 MQ 异步削峰

7. 订单状态错乱

  • 状态机严格控制
  • 只能正向流转,不能乱跳状态

订单全业务时序图

相关推荐
就改了31 分钟前
Zipkin 快速上手部署与接入实战
微服务·zipkin·微服务链路追踪
JiaHao汤1 小时前
分布式事务方案全景:从理论到 Seata 落地
java·分布式·spring·spring cloud
Wyc724092 小时前
Nacos
spring cloud
ywl4708120872 小时前
jwt生产token,简单版helloworld
java·数据库·spring
南部余额2 小时前
RabbitMQ 进阶:延迟队列完全指南
java·分布式·spring·rabbitmq
phltxy2 小时前
Spring AI Agents 智能体模式实战
java·人工智能·spring
phltxy3 小时前
Spring AI 可观测性与 Zipkin 实战
java·人工智能·spring
凡人叶枫5 小时前
Effective C++ 条款35:考虑 virtual 函数以外的其他选择
java·c++·spring
鹅城剑仙6 小时前
Spring Boot 微服务架构设计与最佳实践
spring boot·后端·微服务
Wyc724096 小时前
Seata
spring cloud