在 Redis 中流水线 MULTI/EXEC

问题描述

不太清楚管道交易是否是正确的做法。流水线的吞吐量增益是显着的。

Benchmark.ips do |x|
  x.report("non-pipelined") do
    redis.watch("key")
    redis.multi
    redis.setex("key",3600,123)
    redis.exec
  end
  x.report("pipelined") do
    redis.watch("key")
    redis.pipelined do
      redis.multi
      redis.setex("key",123)
      redis.exec
    end
  end
end

Warming up --------------------------------------
       non-pipelined    10.000  i/100ms
           pipelined    17.000  i/100ms
Calculating -------------------------------------
       non-pipelined     95.237  (± 9.5%) i/s -    470.000  in   5.015991s
           pipelined    177.370  (±10.7%) i/s -    884.000  in   5.054327s

我担心 MULTI 可能无法成功执行,但 SET 仍会在事务之外处理。这听起来不是一个好习惯。

有什么想法吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)