我对redis 4使用简单的lua脚本:
local result = {}
local vcounters = redis.call( "zrange", "vcounters::"..date, 0, -1, "withscores" )
local i = 1
while i < #vcounters do
local vid = vcounters[i]
if result[vid] == nil then result[vid] = 0 end
result[vid] = result[vid] +
(redis.call("scard", "vcounters::"..date.."::session::"..vid) or 0)
i = i + 2
end
return cjson.encode(result)它是来自客户端脚本的替代zrange/scard命令,工作速度快4-5倍。但是这个脚本是否会阻止zadd命令呢?
发布于 2018-01-04 16:47:02
是的,当脚本运行时,不会执行任何其他数据库命令(它们必须wait until it is done)。
从好的方面来说,如果您需要它是原子的,那么脚本也不会与并发的数据库更新交错(而从客户端发出的单个命令可能会与来自其他客户端的命令混合)。
https://stackoverflow.com/questions/48091418
复制相似问题