openresty 连接redis

Redis是非常优秀的基于键值对的内存数据库,在项目中使用非常广泛。在高并发的项目中,经常会需要进行缓存的预热,或者部分数据在接入层就可以进行渲染,那么nginx和redis就成了绝配。在openresty之前,想要在nginx中连接redis那是非常难的一件事情,而有了openresty之后,一切就变得非常简单了。

1、安装redis

如果是要安装最新版本的redis,需要依赖gcc 5.3以上版本,对于现在主流的CentOS系统,默认安装的版本是4.8.5,所以在编译的时候会报错。

 
看到这个错误之后,升级GCC的版本就行了,整体执行如下:
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的使用。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenResty中使用Redis的过程是通过Lua脚本来实现的。首先,需要进行准备工作,确保OpenRestyRedis环境的配置正确。OpenResty主要用于解决高并发问题,而为了避免数据库成为高并发的瓶颈,操作Redis变得不可避免。 如果对OpenResty不太了解,可以参考相关文章进行学习。在Windows系统下,可以使用ZeroBrane Studio进行开发和调试OpenResty代码。 在使用OpenResty操作Redis之前,需要将相关的代码添加到配置文件中。具体的配置数据可以根据自己的Redis数据库情况进行修改。配置文件中包含了连接信息、超时时间以及Redis的库等信息。 在使用OpenResty时,可以根据具体的需求和场景,编写Lua脚本来操作Redis,实现数据的读取、写入和删除等操作。通过调用相关的Redis命令,可以实现与Redis的交互。 总结来说,OpenResty中使用Redis的过程是通过Lua脚本与Redis进行交互,通过配置文件设置Redis连接信息和相关参数,然后根据需求编写Lua脚本来操作Redis中的数据。这样可以有效地解决高并发问题并提升系统性能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [OpenResty高并发最佳实践--Redis操作](https://blog.csdn.net/lupengfei1009/article/details/86160652)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值