关于java幂等性

前言:拖了五个月的总结,事实证明都是要还的。
 

关于java的幂等性,是公司在进行代码评审的时候听到的。以下就根据自己的理解大概写一些。

如果有错的地方请直接指出,本人基础还不够。

参考文章:https://blog.csdn.net/chengzhezhijian/article/details/49276713

1、何为幂等性?

幂等性即为无论请求几次,最后的结果都是一样的。

2、幂等性在什么地方做控制?

一般在分布式系统中,所谓的分布式,即指同时发起多个并行请求(应该是这样的吧),数据可能会被同时操作同样的操作。这样的话如果不做好控制,数据容易被篡改,变成各种奇怪的脏数据。现在很多的文章例子都用付钱这个例子来举例说明。付钱的时候,客户的请求到服务端,此时是否真的数据被修改我们并不得知,如果系统出现缓慢或者其他情况,可能同一种操作就被请求了多次,这样钱可能被扣了多次。所以我们必须对数据进行控制,防止出现数据丢失或者数据脏乱。

3、怎么做幂等性?

幂等性可以从数据出发。

A、可以利用数据处理中创建一个唯一识别码,达到每次处理数据时首先去对比这个识别码是否重复。

B、请求时通过redis加锁做控制。

C、数据库里可以加锁,乐观锁,悲观锁(这两个锁后续展开)

如果有其他的方法后续补充。

4、关于http的幂等性?

get为查询,所以为幂等;put为修改,为幂等;delete为删除,为幂等;post为增加或修改等,不为幂等。

两次相同的POST请求会在服务器端创建两份资源,它们具有不同的URI;所以,POST方法不具备幂等性(来自参考文章)。

最后:写的比较仓促,总结就是,在代码设计中需要考虑数据的幂等性等。不能造成数据多次被处理,如果数据不幂等了该怎么处理,可以通过事务或者捕捉错误来进行回滚操作等。

幂等是个好东西,要学会处理和思考应用。

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值