Nginx+Lua+Redis鏈接池

    上篇介紹了若是使用Lua訪問Redis,可是每次都是從新建立一個鏈接到Redis,其實更好的方法是使用Redis鏈接池。 redis

    若是建立Redis鏈接池呢?原理是用Nginx的Upstream來實現,在Nginx啓動時就能夠建立多條socket鏈接到RedisServer,而後咱們只要把請求發送到該Upstream便可,具體來配置文件。     shell

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模塊。 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")
相關文章
相關標籤/搜索