一、幂等性概念

在编程中.一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同。幂等函数,或幂等方法,是指可以使用相同参数重复执行,并能获得相同结果的函数。这些函数不会影响系统状态,也不用担心重复执行会对系统造成改变。例如,“getUsername()和setTrue()”函数就是一个幂等函数. 更复杂的操作幂等保证是利用唯一交易号(流水号)实现.

我的理解:幂等就是一个操作,不论执行多少次,产生的效果和返回的结果都是一样的。

二、幂等性场景

1、查询操作:查询一次和查询多次,在数据不变的情况下,查询结果是一样的。select是天然的幂等操作;

2、删除操作:删除操作也是幂等的,删除一次和多次删除都是把数据删除。(注意可能返回结果不一样,删除的数据不存在,返回0,删除的数据多条,返回结果多个) ;

3、唯一索引:防止新增脏数据。比如:支付宝的资金账户,支付宝也有用户账户,每个用户只能有一个资金账户,怎么防止给用户创建资金账户多个,那么给资金账户表中的用户ID加唯一索引,所以一个用户新增成功一个资金账户记录。要点:唯一索引或唯一组合索引来防止新增数据存在脏数据(当表存在唯一索引,并发时新增报错时,再查询一次就可以了,数据应该已经存在了,返回结果即可);

4、token机制:防止页面重复提交。

原理上通过session token来实现的(也可以通过redis来实现)。当客户端请求页面时,服务器会生成一个随机数Token,并且将Token放置到session当中,然后将Token发给客户端(一般通过构造hidden表单)。

下次客户端提交请求时,Token会随着表单一起提交到服务器端。

服务器端第一次验证相同过后,会将session中的Token值更新下,若用户重复提交,第二次的验证判断将失败,因为用户提交的表单中的Token没变,但服务器端session中Token已经改变了。

5、悲观锁

获取数据的时候加锁获取。select * from table_xxx where id='xxx' for update; 注意:id字段一定是主键或者唯一索引,不然是锁表,会死人的;悲观锁使用时一般伴随事务一起使用,数据锁定时间可能会很长,根据实际情况选用;

6、乐观锁——乐观锁只是在更新数据那一刻锁表,其他时间不锁表,所以相对于悲观锁,效率更高。乐观锁的实现方式多种多样可以通过version或者其他状态条件:

1. 通过版本号实现update table_xxx set name=#name#,version=version+1 where version=#version#;

2. 通过条件限制 update table_xxx set avai_amount=avai_amount-#subAmount# where avai_amount-#subAmount# >= 0要求:quality-#subQuality# >= ,这个情景适合不用版本号,只更新是做数据安全校验,适合库存模型,扣份额和回滚份额,性能更高;

7、分布式锁

如果是分布式系统,构建全局唯一索引比较困难,例如唯一性的字段没法确定,这时候可以引入分布式锁,通过第三方的系统(redis或zookeeper),在业务系统插入数据或者更新数据,获取分布式锁,然后做操作,之后释放锁,这样其实是把多线程并发的锁的思路,引入多多个系统,也就是分布式系统中得解决思路。要点:某个长流程处理过程要求不能并发执行,可以在流程执行之前根据某个标志(用户ID+后缀等)获取分布式锁,其他流程执行时获取锁就会失败,也就是同一时间该流程只能有一个能执行成功,执行完成后,释放分布式锁(分布式锁要第三方系统提供);

8、select + insert

并发不高的后台系统,或者一些任务JOB,为了支持幂等,支持重复执行,简单的处理方法是,先查询下一些关键数据,判断是否已经执行过,在进行业务处理,就可以了。注意:核心高并发流程不要用这种方法;

9、状态机幂等

在设计单据相关的业务,或者是任务相关的业务,肯定会涉及到状态机(状态变更图),就是业务单据上面有个状态,状态在不同的情况下会发生变更,一般情况下存在有限状态机,这时候,如果状态机已经处于下一个状态,这时候来了一个上一个状态的变更,理论上是不能够变更的,这样的话,保证了有限状态机的幂等。注意:订单等单据类业务,存在很长的状态流转,一定要深刻理解状态机,对业务系统设计能力提高有很大帮助

10、对外提供接口的api如何保证幂等

如银联提供的付款接口:需要接入商户提交付款请求时附带:source来源,seq序列号;source+seq在数据库里面做唯一索引,防止多次付款(并发时,只能处理一个请求) 。

重点:对外提供接口为了支持幂等调用,接口有两个字段必须传,一个是来源source,一个是来源方序列号seq,这个两个字段在提供方系统里面做联合唯一索引,这样当第三方调用时,先在本方系统里面查询一下,是否已经处理过,返回相应处理结果;没有处理过,进行相应处理,返回结果。注意,为了幂等友好,一定要先查询一下,是否处理过该笔业务,不查询直接插入业务系统,会报错,但实际已经处理了。

三、总结

幂等与你是不是分布式高并发还有JavaEE都没有关系。关键是你的操作是不是幂等的。一个幂等的操作典型如:把编号为5的记录的A字段设置为0这种操作不管执行多少次都是幂等的。一个非幂等的操作典型如:把编号为5的记录的A字段增加1这种操作显然就不是幂等的。要做到幂等性,从接口设计上来说不设计任何非幂等的操作即可。譬如说需求是:当用户点击赞同时,将答案的赞同数量+1。改为:当用户点击赞同时,确保答案赞同表中存在一条记录,用户、答案。赞同数量由答案赞同表统计出来。在设计系统时,是首要考虑的问题,尤其是在像支付宝,银行,互联网金融公司等涉及的都是钱的系统,既要高效,数据也要准确,所以不能出现多扣款,多打款等问题,这样会很难处理,用户体验也不好。

幂等性 第三方交易编号_java幂等性的解决方案相关推荐

  1. 数据接口请求异常:parerror_什么是接口的幂等性,如何实现接口幂等性?

    (一)幂等性概念 幂等性原本是数学上的概念,用在接口上就可以理解为:同一个接口,多次发出同一个请求,必须保证操作只执行一次. 调用接口发生异常并且重复尝试时,总是会造成系统所无法承受的损失,所以必须阻 ...

  2. 什么是接口的幂等性,如何实现接口幂等性?一文搞定

    微信搜索<Java鱼仔>,每天一个知识点不错过 每天一个知识点 什么是接口的幂等性,如何实现接口幂等性? (一)幂等性概念 幂等性原本是数学上的概念,用在接口上就可以理解为:同一个接口,多 ...

  3. 成就解锁:BCH修复了所有常见的第三方交易延展性矢量

    在BCH的最近一次升级中,有一项升级内容属于修复程序-在脚本中强制执行MINIMALDATA. 根据之前的升级规范,我们也清楚的了解到,这项更改是为了消除最终的BIP 62延展性矢量,使得升级之后的比 ...

  4. Word中定义的标题编号变成竖线的解决方案

    Word中定义的标题编号变成竖线的解决方案 解决方法 Word 中定义的多级标题后,在文中标题前经常会出现加粗的竖线,试过很多方法,但是基本上都是治标不治本,每次重新打开后又会出现小竖线. 经过本人百 ...

  5. java幂等控制_JAVA幂等性实现

    什么是幂等: 贴一张百度百科的图: 简单来说幂等保证了只要调用接口成功,外部多次调用对系统的影响是一致的,也就是一个请求多次重试的问题. 需要考虑幂等的场景: 客户端存在多次提交或者超时重试的情况: ...

  6. java高并发递增编号_java 高并发 订单编号递增(解决方案)

    业务描述: 首先从数据中查找最近的一条订单数据,然后将之前的订单号码+1作为新的订单号码,插入到数据库当中.(需求不能改变) 当出现并发操作时,A从数据库中获取最近一条订单的订单号为N,这是A还没有完 ...

  7. 什么是幂等性?四种接口幂等性方案详解

    幂等性在我们的工作中无处不在,无论是支付场景还是下订单等核心场景都会涉及,也是分布式系统最常遇见的问题,除此之外,也是大厂面试的重灾区. 知道了幂等性的重要性,下面我就详细介绍幂等性以及具体的解决方案 ...

  8. springboot幂等性_SpringBoot+Redis实现接口幂等性,就看这篇了

    介绍 幂等性的概念是,任意多次执行所产生的影响都与一次执行产生的影响相同,按照这个含义,最终的解释是对数据库的影响只能是一次性的,不能重复处理.手段如下 数据库建立唯一索引 token机制 悲观锁或者 ...

  9. word图表标签与编号之间空格删除解决方案

    问题描述: 使用word[插入题注]功能时,标签和编号之间会自动产生空格(如下图),而中文写作是不需要这个空格的. 解决方案: 如果已经正文已全部写好,只需手动删除,或批量删除.更新域后不会影响修改. ...

最新文章

  1. 简单介绍python连接telnet和ssh的两种方式
  2. 波士顿动力送狗抗疫:头顶iPad,背装对讲机,说是减少医患接触,但性价比真的OK吗?...
  3. 零基础掌握极大似然估计
  4. 常见mysql性能优化方法
  5. DNS服务器全面解析--转
  6. ASP.NET MVC Action向视图传值之匿名类型
  7. scrapyd远程连接配置
  8. VS2008和VS2010水晶报表版本冲突的问题解决
  9. Python与开源GIS:在OGR中使用SQL语句进行查询
  10. 五种常见的linux系统有哪些,常见的Linux操作系统有哪些
  11. 用计算机绘制函数图像结题报告,《几何画板》在高中数学教学中的应用小课题结题报告...
  12. 计算机专业电子技术基础教学,计算机专业“电子技术基础”教学上的难题及对策.doc...
  13. 微信小程序选项卡 点击导航内容切换 滑动内容导航切换
  14. 学习HALCON视觉必会的入门知识| 东哥机器视觉培训
  15. Excel表VLOOKUP多个条件匹配数据
  16. 新西兰计算机科学硕士哪所大学最好,2020年新西兰哪些大学计算机科学专业比较好及其优势介绍...
  17. pyqt 事件更新图片显示_暗黑战神3D网游ARPG实战案例(Unity 2017.3)更新
  18. iOS16更新后打不开微信 解决办法来了
  19. Flink 多流转换
  20. 惯性导航原理(二)-平台式+捷联式+INS精度

热门文章

  1. 卷积神经网络中十大拍案叫绝的操作!
  2. 清晰易懂的Numpy入门教程
  3. 面试官问:请拿出一段体现你水平的代码,我该如何回答?
  4. ACMNO.48 01字串
  5. 利用OpenCV+ConvNets检测几何图形
  6. 算法工程师面试必考项:二叉树
  7. 第二项目AIaisell(易销宝)
  8. 浏览器从输入url到页面加载完成发生了什么
  9. 用shell解决ddos攻击实例
  10. C#使用 SharpSSH