1

我正在围绕hiredis编写一个包装器,以便在redis节点出现故障时启用重新连接的发布/订阅功能。

我正在使用异步 redis API。

所以我有一个测试工具来设置发布者和订阅者。然后,该线束关闭订阅者正在读取的从属 VM。

但是,断开回调直到很久以后才被调用(当我破坏包含相应 redisAsyncContext 的 Subscription 对象时)

我认为解决此问题的方法可能是使用 tcp keepalive。

于是我发现net.h中有一个合适的redis函数:

int redisKeepAlive (redisContext* c, int interval);

但是,以下内容似乎表明库中故意省略了 redisKeepAlive 函数:

$ nm libhiredis.a --demangle | grep redisKeepAlive
0000000000000030 T redisKeepAlive
                 U redisKeepAlive

$ nm libhiredis.a -u --demangle | grep redisKeepAlive
             U redisKeepAlive

当然,当我尝试使用该调用时,链接器会抱怨:

Subscription.cpp:167: undefined reference to `redisKeepAlive(redisContext*, int)'
collect2: error: ld returned 1 exit status

我运气不好 - 有没有办法在 Hiredis 异步上下文上设置 TCP keepalive 间隔?

更新 我发现了这个:

int redisEnableKeepAlive(redisContext *c);

但是在 asyncContext->c 上设置它并调整 REDIS_KEEPALIVE_INTERVAL 似乎没有效果。

4

1 回答 1

0

我发现redisKeepAlive的实现包含显示如何直接访问底层套接字描述符的代码:

int redisKeepAlive(redisContext *c, int interval) {
int val = 1;
int fd = c->fd;

if (setsockopt(fd, SOL_SOCKET, SO_KEEPALIVE, &val, sizeof(val)) == -1){
    __redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
    return REDIS_ERR;

}

也许这会帮助某人..

于 2017-08-11T08:06:06.257 回答