2012-11-26 118 views
1

我试图在断开连接时重新连接到Redis服务器。与hiredis重新连接

我正在使用redisAsyncConnect,并且我在断开连接时设置了回调。在回调中,我尝试重新连接与我在程序开始时使用的相同命令来建立连接,但它不起作用。似乎无法重新连接。

任何人都可以帮我一个例子吗?

+0

您可以查看redis Ruby gem代码并查看它的功能。有了宝石,如果有断开连接,下一个命令似乎可靠地重新建立连接。 – Gene

回答

2

当使用事件循环时,异步管理Redis(re)连接有点棘手。

下面是一个实现小型zset轮询守护程序的示例,该守护程序连接到Redis实例列表,这对于断开连接事件是有弹性的。使用ae事件循环(这是Redis自己使用的循环)。

http://gist.github.com/4149768

检查以下功能:

  • connectCallback
  • disconnectCallback
  • checkConnections
  • reconnectIfNeeded

主要daemo只有当连接可用时,n循环才会执行其活动。每秒一次,第二次启动回调检查是否必须重新建立一些连接。我们发现这种机制相当可靠。

注意:为简洁起见,此示例中的错误管理很粗糙。真正的生产代码应该以更优雅的方式管理错误。

处理多个异步连接时的一个棘手问题是,没有用户定义的上下文数据作为相应回调的参数传递。在断开连接事件后清除与连接相关的数据可能有点困难。

+0

感谢Didier,正是我所需要的。我想出了一些非常相似的东西,但是我没有将回调重新附加到事件循环中。不知道这是否是问题,因为还有其他差异,但您的示例非常有帮助。 – gkres