Nginx+Lua+Redis连接池

本文介绍如何利用Nginx Upstream配置创建Redis连接池,提升并发性能,并展示了一个自定义Lua模块用于简化Redis操作流程。通过设置连接池,减少连接创建和关闭的开销,提高Redis访问效率。

    上篇介绍了如果使用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")



转载于:https://my.oschina.net/netflasher/blog/662581

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值