上篇介绍了如果使用Lua访问Redis,但是每次都是重新创建一个连接到Redis,其实更好的方法是使用Redis连接池。
如果创建Redis连接池呢?原理是用Nginx的Upstream来实现,在Nginx启动时就可以创建多条socket连接到RedisServer,然后我们只要把请求发送到该Upstream即可,具体来配置文件。
upstream redis_pool {
server 127.0.0.1:6379;
keepalive 1024;
}
这样就创建了redis连接池,
接着在配置文件里面添加一个location。
location /get_redis{
set_unescape_uri $query $arg_query;
redis2_raw_query $query;
redis2_pass redis_pool;
}
接下来就是如果使用redis连接池了。我写了一个lua模块。
RedisManager = {}
RedisManager.runCommand = {}
local metatable = {
__call = function(table , ...)
command = nil
args = ''
for key, value in ipairs({...}) do
if not command then
command = value
else
args = args .. " " .. value;
end
end
command = command .. " " .. args .. '\r\n'
-- return command
local res = ngx.location.capture("/get_redis",{
args = { query = command}
})
return res.body
end
}
setmetatable(RedisManager.runCommand, metatable);
return RedisManager
在使用的时候记得require("RedisManager"),然后只需要这样调用
RedisManager.runCommand("set", "dog", "hhhh")
runCommand是变长参数。我们只需要添加这些参数即可,使用方式和redis的command是一样的。如
RedisManager.runCommand("hset", "user-1", "name", "JimGreen")
RedisManager.runCommand("hget", "user-1", "name")