【JavaP6大纲】功能设计篇:幂等性实现

简介: 【JavaP6大纲】功能设计篇:幂等性实现

幂等性实现


乐观锁:数据库:通过version或者时间翻防止其他操作并发更新,更新先败露有一定的重试机制。CASH较与交换也是乐观锁。


去重表:在插入数据的时候,插入去重表,利用数据库的唯一產引特性,保证唯一的逻辑,这种方法适用于在业务中有唯一标的插入场景中,比在以上的支付场景中,如果一个订单只会支付一次所以订单ID可以作为唯一标识。这时,我们就可以建一张去重表,并且把唯一标识作为唯一索引,在我们实现时,把创建支付单据和写入去去重表,放在一个事务中,如果重复创建, 数据库会抛出唯约束异常,操作就会回滚,不做任何操作,实现了幕等。


悲观锁:select for update,当线程A执行for update,数据会对当前记录加锁,其他线程执行到此行代码的时候,会等待线程A释放锁之后,才可以获取锁,继续后续操作。事物提交时,for update获取的锁会自动释放。如果业务处理比较耗时,并发情况下,后面线程会长期处于等待状态,占用了很多线程,让这些线程处于无效等待状态,我们的web服务中的线程数量一般都是有限的,如果大量线程由于获取for update锁处于等待状态,不利于原统并发操作。


状态机:在消费者业务表中存在状态字段,并在消费消息后是变更状态,状态流转是年

例如:status:11 -)2→3=4.1基于数据库乐观锁 CAS方式。例如:update table set status = 2.,. where status = 1


数据库唯一约束:消息消费者在业务表中重要存储上游业务唯—id,在消息这业务表中加入上游业务唯一d并设置为唯一约束。

相关文章
|
2月前
|
SQL 关系型数据库 MySQL
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
课程分类查询、课程新增、统一异常处理、统一封装结果类、JSR303校验、修改课程、查询课程计划、新增/修改课程计划
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
|
4月前
codereview开发问题之CodeReview在命名规范中,常见问题如何解决
codereview开发问题之CodeReview在命名规范中,常见问题如何解决
|
4月前
codereview开发问题之CodeReview中如何判断注释问题如何解决
codereview开发问题之CodeReview中如何判断注释问题如何解决
|
4月前
|
存储 Java
软件开发常用之SpringBoot文件上传接口编写(中),一本书,代码大全(里面有很多代码重构的方法),屎山代码的原因是不断追加逻辑,在错误代码上堆积新的功能,在写完逻辑之后去思考一下,逻辑合理不
软件开发常用之SpringBoot文件上传接口编写(中),一本书,代码大全(里面有很多代码重构的方法),屎山代码的原因是不断追加逻辑,在错误代码上堆积新的功能,在写完逻辑之后去思考一下,逻辑合理不
|
6月前
|
SQL Web App开发 存储
面试题5: 如何编写提交给用户的测试报告?
面试题5: 如何编写提交给用户的测试报告?
面试题5: 如何编写提交给用户的测试报告?
|
安全 测试技术
不会写测试用例咋办?牢记这5点,你也能写出高逼格案例
不会写测试用例咋办?牢记这5点,你也能写出高逼格案例
134 1
|
前端开发 API
【面试题】:前端怎么实现权限设计及遇到的bug
前端怎么实现权限设计及遇到的bug
208 0
|
Java 编译器
编程基础|如何解决编程中的代码错误问题
编程基础|如何解决编程中的代码错误问题
246 0
|
数据库
【JavaP6大纲】分布式事务篇:最大努力通知
【JavaP6大纲】分布式事务篇:最大努力通知
100 0
|
NoSQL Java Redis
【JavaP6大纲】SpringCould篇:如何限流?在工作中是怎么做的?说一下具体的实现?
【JavaP6大纲】SpringCould篇:如何限流?在工作中是怎么做的?说一下具体的实现?