首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >两个进程可以使用Watch更改相同的Redis资源。我是不是该担心生动活泼?

两个进程可以使用Watch更改相同的Redis资源。我是不是该担心生动活泼?
EN

Stack Overflow用户
提问于 2014-10-09 13:16:02
回答 1查看 232关注 0票数 6

进程A和B都在Redis资源R上运行。

这些进程可以并行执行,我需要这两个进程在它们改变R的时候确定R的值。

因此,我将Redis交易监视命令结合使用。在文档中:“只有当没有其他客户端修改任何WATCHed键时,我们才要求Redis执行事务。否则事务根本不会被输入。”

要在失败时重新尝试,建议的方法是循环Watch/Multi-exec循环,直到它成功。但是,我担心A和B可能都会开始无限期地循环(即: livelock)。

有什么好担心的吗?更好的是,该怎么办呢?在重试中设置一个随机超时会解决这个问题吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-09 14:04:57

不需要担心,因为只有A或B会成功地执行和更改R (Redis大多是单线程的)。如果失败,则需要使用新的R值重试事务。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26279412

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档