上篇介紹了若是使用Lua訪問Redis,可是每次都是從新建立一個鏈接到Redis,其實更好的方法是使用Redis鏈接池。 redis
若是建立Redis鏈接池呢?原理是用Nginx的Upstream來實現,在Nginx啓動時就能夠建立多條socket鏈接到RedisServer,而後咱們只要把請求發送到該Upstream便可,具體來配置文件。 shell
upstream redis_pool { server 127.0.0.1:6379; keepalive 1024; }
location /get_redis{ set_unescape_uri $query $arg_query; redis2_raw_query $query; redis2_pass redis_pool; }
接下來就是若是使用redis鏈接池了。我寫了一個lua模塊。 socket
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"),而後只須要這樣調用 ui
RedisManager.runCommand("set", "dog", "hhhh")
runCommand是變長參數。咱們只須要添加這些參數便可,使用方式和redis的command是同樣的。如 lua
RedisManager.runCommand("hset", "user-1", "name", "JimGreen")
RedisManager.runCommand("hget", "user-1", "name")