应用程序在多台机器上部署,且数据源只有一个,在高并发的情况下,如何保证数据的准确性?
程序伪代码:
// 读取账户信息,并且余额加100
Account account = findAccount();
account.setBalance(account.getBalance() + 100);
updateAccount(account);
这个应用程序在多台机器上部署,如果保证数据的准确性。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
事务,然后加悲观锁或者乐观锁
对这种情况,可以直接改下逻辑,不要先set再update, 直接传要修改的值 update XXX set balance = blance + change,更复杂的只能用事务了,甚至分布式事务。。。
参考:
有个东西叫幂等 https://www.zhihu.com/questio...
单写库,可以利用数据库的事务的隔离性来解决啊。 而且计算不要在应用层,要在DB中。