开发者社区> 问答> 正文

在redis中,需要获取当前值,然后再决定以后的行为,这个过程需要原子性,怎么实现?

初步看来,需要使用redis事务,然而redis事务中的命令并不立即不执行,无法获取当前的数据。
可有其他的解决办法?

展开
收起
爵霸 2016-03-09 10:27:00 2225 0
2 条回答
写回答
取消 提交回答
  • 就职于阿里云数据库技术组,从事redis引擎开发工作,https://github.com/soloestoy

    楼上正解,watch和multi/exec组合使用

    2019-07-17 18:55:31
    赞同 展开评论 打赏
  • 开发中正好遇到,场景是需要控制对用户的账号余额进行扣费操作,所以需要先读取原值,减去,再更新。
    使用了watch,以及mutil和exec组合,首先你需要watch需要操作的key,然后读取key的值,计算好新值,然后执行mutil开启事务,执行set命令更新key值,再执行exec提交事务,如果key的值在你watch之后exec之前有发生变化,那么你的set就不会执行成功,未变化可以执行成功。
    这样就可以保证原子性了。

    2019-07-17 18:55:31
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Redis在唯品会的应用实践——架构演进与功能定制 立即下载
微博的Redis定制之路 立即下载
云数据库Redis版的开源之路 立即下载