猿问

支付系统 遇到了一个读取账户余额加锁的问题 该如何解决

第一次做支付系统,我们平台有很多商户,每个商户每分钟订单很多,量很大,我用异步方式给商户账户更新余额,用的mysql队列,每笔订单成功都会往队列里加如一条,crontab来读取更新增加账户余额,但是碰到了一个提现的问题

提现我是这么做的,账户余额减去提现金额,然后再把剩余的钱更新到账户余额字段,问题就有了!

1.提现的时候拿到账户余额为10块,要提现5块,提现操作正在进行,但是这个时候进来一笔5块的订单,异步要更新账户,拿到的还是10块,加上5块,然后把15元更新到余额字段中,这时候提现操作也在进行,提现了5块,然后在把剩余的5块更新到余额字段, 覆盖了之前的15,

2.我没有在提现查询余额的时候加锁,加锁能否解决问题呢,除了加锁,是否还有其他更好的方法解决呢。这个异步更新账户余额的逻辑和提现的逻辑是否需要改进呢。希望大家能能大家给点意见谢谢

第一条是入账的,第一个字段是ID 第二个余额,第三个订单金额,第四个更新完后的余额,
第二条是提现的,第二个余额,第三个是提现的金额,第四个同上

蝴蝶刀刀
浏览 960回答 1
1回答

动漫人物

增加余额set&nbsp;autocommit=0;update&nbsp;<table>&nbsp;set&nbsp;balance=balance+<xxx>&nbsp;where&nbsp;id=<id>;select&nbsp;*&nbsp;from&nbsp;<table>&nbsp;where&nbsp;id=<id>commit;保证上面2条语句在同一个事务中执行。最终在程序中做运算。balance - <xxx>&nbsp;就是增加前的余额balance&nbsp;就是增加后的余额提现set&nbsp;autocommit=0;update&nbsp;<table>&nbsp;set&nbsp;balance=balance-<xxx>&nbsp;where&nbsp;id=<id>&nbsp;and&nbsp;balance>=<xxx>;select&nbsp;*&nbsp;from&nbsp;<table>&nbsp;where&nbsp;id=<id>;commit;保证上面2条语句在同一个事务中执行。最终在程序中做运算。balance + <xxx>&nbsp;就是提现前的余额balance&nbsp;就是提现后的余额
随时随地看视频慕课网APP

相关分类

Html5
我要回答