位置: 编程技术 - 正文

高并发系统数据幂等的解决方案(高并发数据库解决方案)

编辑:rootadmin

推荐整理分享高并发系统数据幂等的解决方案(高并发数据库解决方案),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:怎么处理高并发数据,高并发数据处理,怎么处理高并发数据,高并发数据库解决方案,高并发数据处理,高并发系统如何设计,高并发系统数据怎么处理,高并发系统数据怎么处理,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

在系统开发过程中,经常遇到数据重复插入、重复更新、消息重发发送等等问题,因为应用系统的复杂逻辑以及网络交互存在的不确定性,会导致这一重复现象,但是有些逻辑是需要有幂等特性的,否则造成的后果会比较严重,例如订单重复创建,这时候带来的问题可是非同一般啊。

什么是系统的幂等性

幂等是数据中得一个概念,表示N次变换和1次变换的结果相同。

高并发的系统如何保证幂等性?

1.查询

查询的API,可以说是天然的幂等性,因为你查询一次和查询两次,对于系统来讲,没有任何数据的变更,所以,查询一次和查询多次一样的。

2.MVCC方案

多版本并发控制,update with condition,更新带条件,这也是在系统设计的时候,合理的选择乐观锁,通过version或者其他条件,来做乐观锁,这样保证更新及时在并发的情况下,也不会有太大的问题。

高并发系统数据幂等的解决方案(高并发数据库解决方案)

例如:update table_xxx set name=#name#,version=version+1 where version=#version# ,或者是 update table_xxx set quality=quality-#subQuality# where quality-#subQuality# >= 0 。

3.单独的去重表

如果涉及到的去重的地方特别多,例如ERP系统中有各种各样的业务单据,每一种业务单据都需要去重,这时候,可以单独搞一张去重表,在插入数据的时候,插入去重表,利用数据库的唯一索引特性,保证唯一的逻辑。

4.分布式锁

还是拿插入数据的例子,如果是分布是系统,构建唯一索引比较困难,例如唯一性的字段没法确定,这时候可以引入分布式锁,通过第三方的系统,在业务系统插入数据或者更新数据,获取分布式锁,然后做操作,之后释放锁,这样其实是把多线程并发的锁的思路,引入多多个系统,也就是分布式系统中得解决思路。

5.删除数据

删除数据,仅仅第一次删除是真正的操作数据,第二次甚至第三次删除,直接返回成功,这样保证了幂等。

6.插入数据的唯一索引

插入数据的唯一性,可以通过业务主键来进行约束,例如一个特定的业务场景,三个字段肯定确定唯一性,那么,可以在数据库表添加唯一索引来进行标示。

这里有一个场景,API层面的幂等,例如提交数据,如何控制重复提交,这里可以在提交数据的form表单或者客户端软件,增加一个唯一标示,然后服务端,根据这个UUID来进行去重,这样就能比较好的做到API层面的唯一标识。

7.状态机幂等

在设计单据相关的业务,或者是任务相关的业务,肯定会涉及到状态机,就是业务单据上面有个状态,状态在不同的情况下会发生变更,一般情况下存在有限状态机,这时候,如果状态机已经处于下一个状态,这时候来了一个上一个状态的变更,理论上是不能够变更的,这样的话,保证了有限状态机的幂等。

标签: 高并发数据库解决方案

本文链接地址:https://www.jiuchutong.com/biancheng/318929.html 转载请保留说明!

上一篇:SQL Server数据表字段自定义自增数据格式的方法(sql server数据表的关联)

下一篇:SQL查询服务器硬盘剩余空间(sql查询服务器硬件信息)

  • 产权转让印花税计税依据
  • 总账会计和全盘会计的区别
  • 填第二季度的利润总额怎么填
  • 建筑工程查帐征收税
  • 回购股份限售
  • 对于子女继承父母的评价
  • 出售专利权收入属于什么收入
  • 油费预付卡如何开发票
  • 房产税城镇土地使用税申报流程
  • 外币报表折算差额在会计报表中应作为
  • 模具维修费用清单表格
  • 个人独资企业是法人吗
  • 印花税到底什么通俗一点
  • 新成立的公司每天付款有要求吗
  • 商贸公司可以申请进出口权吗
  • 职工报销差旅费会计科目
  • 增值说税率怎么计算
  • 个人所得税自行纳税申报
  • 个人所得税违约怎么查询
  • 股票现金分红
  • 记账凭证填制的内容
  • 会计审核票据如何签字
  • 红冲无票收入怎么报税
  • 差旅补助需要计提吗
  • 收不到的物业费是否增值税确认收入
  • 公司资质办理费用
  • wifi安全助手每日提现
  • 十天学会php教程
  • php的数组函数
  • 微信公众平台开发
  • 转让股权怎么做分录
  • 湘菜尖椒炒肉的做法
  • 图像分割最新算法
  • 贝尔·菲戈尔
  • 增值税发票月度统计
  • php时间戳转换成时间
  • 小规模公司购买空调会计分录
  • 体验了才明白的作文范文
  • pgrep命令详解
  • 小规模纳税人增值税超过30万怎么纳税
  • 帝国cms采集发布的文章链接打不开
  • python time. time
  • 非正常损失的增值税进项税额转出
  • mysql 连接过多
  • 期末应交增值税的会计科目怎么做
  • 如何分析成本费用高
  • 自产产品用于内部使用
  • 管理费用 暂估入账
  • 其他应收款在现金流量表怎么填
  • 小轿车折旧年限规定
  • 银行承兑汇票和银行汇票的区别
  • 走逃发票账务处理
  • 专票不报销公司查得到吗
  • 费用报销单和费用核销单一样吗
  • 营改增之后还有营业税金及附加吗
  • sqlserver全文索引ndf文件丢失
  • sql必会知识
  • SqlServer下通过XML拆分字符串的方法
  • 懒癌患者如何自救
  • docker untagged
  • 怎么检测u盘是否扩容
  • xp.系统
  • 硬盘安装ubuntu18
  • linux open o_direct
  • linux中使用grep命令显示包含特殊字符的行
  • dwm22.exe病毒
  • windows7禁用wifi怎么办
  • win8个性化外观恢复默认设置
  • win7 win8.1双系统安装教程
  • js数据的基本类型有哪些
  • Linux数据库备份的命令
  • 常见的dos命令及功能
  • linux .tar文件
  • Qt for Android - ANT_HOME is set incorrectly or ant could not be located
  • 国家税务总局12366上海(国际)纳税服务中心
  • 银行代扣流程
  • 在网上如何查询车辆违章
  • 与税务有关的公需课
  • 国际税收对经济活动的影响
  • 深圳12366接听客服工作怎么样
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设