赞
踩
Redis是非常优秀的基于键值对的内存数据库,在项目中使用非常广泛。在高并发的项目中,经常会需要进行缓存的预热,或者部分数据在接入层就可以进行渲染,那么nginx和redis就成了绝配。在openresty之前,想要在nginx中连接redis那是非常难的一件事情,而有了openresty之后,一切就变得非常简单了。
1、安装redis
如果是要安装最新版本的redis,需要依赖gcc 5.3以上版本,对于现在主流的CentOS系统,默认安装的版本是4.8.5,所以在编译的时候会报错。
- wget http://download.redis.io/releases/redis-6.0.6.tar.gz
- tar -zxvf redis-6.0.6.tar.gz
- make
-
- # 查看gcc版本是否在5.3以上,centos7.8默认安装4.8.5
- gcc -v
-
-
- # 升级gcc
- yum -y install centos-release-scl
- yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
-
- scl enable devtoolset-9 bash
-
- # 需要注意的是scl命令启用只是临时的,退出shell或重启就会恢复原系统gcc版本。
- # 如果要使gcc 9.3的永久生效的话,要将参数写到配置文件里,如下:
-
- echo "source /opt/rh/devtoolset-9/enable" >>/etc/profile

2、连接Redis
lua连接Redis有多种方式,最为稳定也最灵活的是采用lua-resty-redis模块来进行连接。具体步骤如下:
(1)下载redis模块
https://github.com/openresty/lua-resty-redis
(2) 引入redis(注意在http中引入redis模块路径)
local redisClient = require("resty.redis");
(3) 连接redis
- -- 创建redis客户端
- local redis = redisClient:new();
- -- 定义连接的IP地址
- local ip = "127.0.0.1";
- -- 定义连接的端口号
- local port = 6379;
- -- 创建连接
- local ok,err = redis:connect(ip,port);
3、操作Redis常用api
- -- 调用redis的get方法,获取redis中存储的key的值
- local ok,err = redis:get("key");
-
- if not ok then
- ngx.say("get key err",err);
- return;
- end;
4、关闭redis
- local function close_redis(red)
- if not red then
- return;
- end;
-
-
- local pool_max_idle_time = 10000; --毫秒
- local pool_size = 100; --连接池大小
- local ok, err = red:set_keepalive(pool_max_idle_time, pool_size);
- if not ok then
- ngx.say("set keepalive error : ", err);
- end;
- end;
Redis的连接非常简单,API也都非常简单,如果你了解Redis的情况下,很容易能够上手。如果你对Redis不熟悉,可以先去了解下Redis的使用。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。