首先,最快的方法是在eval中完成所有这些操作。
接下来,推荐的迭代所有密钥的方法是SCAN。它的迭代速度不会比快
KEYS,但是将允许Redis在其之间处理一些其他操作,因此将有助于整体应用程序行为。
该脚本将类似于
local data={} local i=1 local mykeys=redis.call("KEYS","*") fork=1,#mykeys do local tmpkey=mykeys[k]data[i]={tmpkey,redis.call("GET",tmpkey)} i=i+1 end returndata,但是如果您具有GET无法访问的键(如集,列表),它将失败。您需要为其添加错误处理。如果需要排序,则可以直接在LUA中进行,也可以稍后在客户端进行。第二个会比较慢,但是不会让其他Redis实例用户等待。样本输出:
127.0.0.1:6370> eval "local data={} local i=1 local mykeys=redis.call("KEYS","*") for k=1,#mykeys do local tmpkey=mykeys[k] data[i]={tmpkey,redis.call("GET",tmpkey)} i=i+1 end return data" 01) 1) "a" 2) "aval"2) 1) "b" 2) "bval"3) 1) "c" 2) "cval"4) 1) "d" 2) "dval"5) 1) "e" 2) "eval"6) 1) "f" 2) "fval"7) 1) "g" 2) "gval"8) 1) "h" 2) "hval"


