Redis 和 Lua 中的连接

这是我的配置:

local rc = require("resty.redis.connector").new({
                connect_timeout = 50,
                read_timeout = 5000,
                keepalive_timeout = 30000
            })

            local redis, err1 = rc:connect({
                url = "redis://127.0.0.1:6379",
            })

            if not redis then
                ngx.say( err1)
            else
                ngx.say('连接正常')
            end

            local ok, err = rc:set_keepalive(redis)

我得到了这个错误:

[error] 4044#0: *1068056 试图在关闭的套接字上发送数据: u:00007F2BABA05D48, c:0000000000000000, ft:0 eof:0, client:我的IP, server: , request: "GET /foo HTTP/1.1", host: "服务器IP"

当我禁用 keepalive 设置时,会得到这个错误:

[error] 4147#0: *1089971 lua tcp 套接字连接超时,当 连接到 127.0.0.1:6379 时。

当我注释掉与 rc:set_keepalive 相关的行时,它可以处理单个请求,但在处理 100 个请求时会崩溃。

在处理大量请求下连接 Redis 的最佳实践是什么?

点赞
用户2060502
用户2060502

你的代码有错误。

  1. redis.new 不接受任何参数。
  2. connect 返回 ok, err。将 ok 值传递给 set_keepalive 是没有意义的。
  3. set_keepalive 接受两个数字作为参数。

RTFM,请遵循文档,你的代码看起来像一个大杂烩,十分抱歉。

2019-07-22 14:35:22
用户1155642
用户1155642

关于在 Lua 中使用 Redis 的最流行方式是lua-resty-redis

关于[error] 4044 # 0:* 1068056尝试在已关闭的套接字上发送数据 我在使用set_timeouts(connect_timeout, send_timeout, read_timeout)方法时遇到了这个问题。

当我转而使用set_timeout(time)方法时,错误消失了。

我没有使用lua-resty-redis-connector,我假设你在你的代码中正在使用。

2019-10-18 08:12:44