幂等(idempotent)
一个幂等操作的特点是:任意多次所产生的影响均与一次执行的影响相同。
幂等函数,可以使用相同参数重复执行,并能获得相同结果的函数。
实现幂等的技术方案:
-
查询,select就是幂等操作
-
删除
-
唯一索引,防止新增脏数据
-
token机制,防止页面重复提交
-
悲观锁,解决并发事务的更新丢失问题
- 使用select … for update来执行(select * from employee where id = 1 for update; )
- 事务A使用悲观锁后,事务B再使用时将会被阻塞
- 使用commit可以解除阻塞
- 解除阻塞后,事务B可以看到事务A的修改
-
乐观锁,(逻辑实现,数据库不提供支持)做法:版本号控制和时间戳控制(每次更新版本号变更)
- 乐观锁只是在更新数据那一刻锁表,其他时间不锁表,所以相对于悲观锁,效率更高
- 通过版本号实现 update table_xxx set name=#name#,version=version+1 where id=#id# and version=#version#
- 通过条件限制 update table_xxx set avai_amount=avai_amount-#subAmount# where id=#id# and avai_amount-#subAmount# >= 0
-
分布式锁
- 通过第三方系统redis或zookeeper,在业务系统插入或更新数据,获取分布式锁,然后操作再释放锁。
-
状态机幂等,有限状态机