栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

重做块直到密钥存在

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

重做块直到密钥存在

如果不在客户端上实现某种池化 redis GET, 就无法做您想做的事情。在这种情况下,您的客户将必须执行以下操作:

async def _fetch(key):    val = self.redis_connection.get(key)    while val is None:       # Sleep and retry here       asyncio.sleep(1)         val = self.redis_connection.get(key)    return val

但是,我要求您完全重新考虑您用于此问题的模式。在我看来,您需要执行诸如Pub / Sub
https://redis.io/topics/pubsub之类的操作。

因此,执行 SET 的应用程序将成为发布者,而执行 GET 并等待密钥可用的应用程序将成为订阅者。

我对此进行了一些研究,看起来您可以使用asyncio_redis来做到这一点:

  • 订阅者https://github.com/jonathanslenders/asyncio-redis/blob/b20d4050ca96338a129b30370cfaa22cc7ce3886/examples/pubsub/receiver.py。

  • 发件人(发布者):https : //github.com/jonathanslenders/asyncio-redis/blob/b20d4050ca96338a129b30370cfaa22cc7ce3886/examples/pubsub/sender.py

希望这可以帮助。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/370241.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号