浅谈电商下单微服务流程

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. 订单状态错乱

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

订单全业务时序图

相关推荐
西安邮电大学5 小时前
SpringBean完整生命周期
java·spring
范什么特西5 小时前
Spring 动态代理 静态代理
java·后端·spring
醇氧5 小时前
Spring 动态注册 Bean 深度解析:从源码到实践
java·后端·spring
vx-程序开发8 小时前
基于机器学习的动漫可视化系统的设计与实现-计算机毕业设计源码08339
java·c++·spring boot·python·spring·django·php
C137的本贾尼9 小时前
Spring AI Alibaba 开箱:国产百炼大模型初体验
java·人工智能·spring
魏杨杨9 小时前
被流量逼出来的架构:从一台服务器到云原生的 17 次蜕变 —— 集群、缓存、MQ、微服务、Docker、K8S 的前世今生
微服务·k8s·负载均衡·ddd·分部署
William Dawson10 小时前
【通俗易懂!Spring四大核心注解源码解读:@Configuration、@ComponentScan、@Import、@EnableXXX实战】
java·后端·spring
菜菜小狗的学习笔记11 小时前
八股(九)杂七杂八
java·后端·spring
我本楚狂人www12 小时前
Spring 两大核心思想(一):IoC
java·数据库·spring