问题描述
不太清楚管道交易是否是正确的做法。流水线的吞吐量增益是显着的。
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 (将#修改为@)