【17 > 分布式接口幂等性】1. 概述与接口重试的问题

一、本章概述

二、接口幂等性

[2.1 定义](#2.1 定义)

[2.2 运用场景](#2.2 运用场景)

[2.3 保证幂等性的策略有哪些?](#2.3 保证幂等性的策略有哪些?)

[2.4 如何实现](#2.4 如何实现)

[2.5 如何操作](#2.5 如何操作)

一、本章概述

  • 什么是幂等性
  • 幂等性设计的 核心思想
  • select、updates、delete、insert 和 混合操作 的接口幂等性

二、接口幂等性

  • 提交订单按钮 如何防止重复提交?
  • 表单录入页 如何防止重复提交?
  • 微服务接口,客户端重试时,会对业务数据产生影响吗?

2.1 定义

  • 幂等性: f(f(x)) = f(x)
  • 幂等元素运行多次,还等于它原来的运算结果
  • 在系统中,一个接口运行多次,与运行一次的效果是一致 的

2.2 运用场景

  • 什么情况下需要幂等性
  • 重复提交、接口重试、前端操作抖动 等
  • 业务场景 : 用户多次点击提交订单,后台应只生成一个订单
  • 业务场景 : 支付时,由于网络问题重发,应该只扣一次钱

并不是所有的接口都要求幂等性,要根据业务而定

2.3 保证幂等性的策略有哪些?

幂等性的核心思想:通过唯一的业务单号保证幂等

2.4 如何实现

  • 非并发情况下,查询业务单号有没有操作过,没有则执行操作
  • 并发的情况下,整个操作过程加锁 (分布式锁)

2.5 如何操作

|----------|---------------------|-----------------------------|
| CRUD | 描述 | 操作 |
| Select | 不会对业务数据有影响,天然幂等 | 无 |
| Delete | 第一次已经删除,第二次也不会有影响 | 无 |
| Update | 更新操作传入数据版本号(唯一业务单号) | 通过乐观锁实现幂等性 |
| Insert | 此时没有唯一业务单号 | 使用Token保证寡等 |
| 混合 | 找到操作的 唯一业务单号 | 有:则可使用分布式锁 没有:可以通过Token保证幂等 |

相关推荐
坤昱3 小时前
cfs调度类深入解刨——最新内核细节分析5
linux·分布式·cfs调度·eevdf调度·linux调度·linux技术·kernel最新版本内容
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题 第91题】【Mysql篇】第21题:分布式锁的使用场景和原理?
java·数据库·分布式·mysql·面试
JAVA社区4 小时前
Java高级全套教程(十三)—— 分布式锁超详细实战详解(原理+三种方案企业级落地)
java·开发语言·分布式·spring cloud·面试·java-zookeeper
Leo1874 小时前
分布式事务
java·分布式·分布式事务
潮起鲸落入海7 小时前
ceph分布式存储认证和授权,块存储管理
分布式·ceph
ZPC82108 小时前
前馈补偿原理 + 分类 + 公式 + 工程实现(配合 PID 使用,从根源减轻闭环收敛压力)
人工智能·分布式·机器人
闪电悠米9 小时前
黑马点评-分布式锁-02_simple_redis_lock_setnx
java·数据库·spring boot·redis·分布式·缓存·wpf
大迪deblog9 小时前
从分布式到中央计算:深度拆解下一代 Zonal 车载 EEA 架构变革
分布式·架构
智塑未来9 小时前
2026轻量化图形引擎生态白皮书:PG官网发布渠道与分布式PG数据库架构全面解析
数据库·分布式·数据库架构
weixin199701080169 小时前
[特殊字符] 电商库存扣减防超卖:分布式锁的三种实现(附Python源码)
开发语言·分布式·python