我正在围绕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 似乎没有效果。