【问题标题】:The veracity of doing hget and hset on the same value in a redis hash (inside a pipeline)在 redis 哈希(在管道内)中对相同值执行 hget 和 hset 的准确性
【发布时间】:2018-03-21 22:50:59
【问题描述】:

在 redis 中,我有一个哈希值,我想首先获取然后设置一个值。我认为我可以使用流水线通过缩小往返行程来加快整个操作,如下所示:

my_pipeline = redis.Redis(connection_pool=POOL).pipeline()
my_pipeline.hget("my_hash","my_time")
my_pipeline.hset("my_hash","my_time",latest_time)
result = my_pipeline.execute()
old_value_of_my_time = result[0]

基本上我试图检索my_time 的原始值以供以后使用,然后设置一个新值。

所以问题是: 在同一管道中对同一值执行 hgethset 是否正确?我从this SO post(和管道的一般知识)了解到,命令的顺序保留在管道中。所以从表面上看,我的方法应该是正确的。

但是我可能会遗漏一些东西,所以专家可以审查这种方法吗?

注意:我在示例代码中使用了 python 语法。此外,如果我不使用哈希,我会简单地使用getset 进行此操作。但请注意,在这种情况下,我必须使用散列 - 出于此问题范围之外的原因。

【问题讨论】:

    标签: redis


    【解决方案1】:

    是的,您可以在管道中执行HGETHSET。但是,它的行为与GETSET 略有不同。 GETSET 是原子操作,但管道中HGETHSET 的组合不是原子的。

    Redis 保证它在您的 HSET 命令之前运行您的 HGET 命令。但是,Redis 不会自动运行这两个命令。所以当它运行你的HSET 命令时,HASH 可能已经被另一个客户端修改了。在这种情况下,您得到的不是旧值,而是一些旧值。

    为了实现类似于GETSET 的功能,您已经在事务中运行了HGETHSET,或者将这两个命令包装在Lua 脚本中。

    【讨论】:

    • redis原生支持原子事务吗?
    • 当然。您可以使用transaction related commandsLua scripting 来实现。
    • 超出了这个问题的范围,但我想我会提出来的。你会说蟒蛇吗?我问是因为在 python 包装器的文档(这里:redis-py.readthedocs.io/en/latest)中,似乎pipeline 默认是用transaction=True 实现的?我只是想确认一下。
    猜你喜欢
    • 2021-11-26
    • 2018-03-16
    • 2021-12-13
    • 1970-01-01
    • 1970-01-01
    • 2014-04-23
    • 2016-06-02
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多