我试图在断开连接时重新连接到Redis服务器。与hiredis重新连接
我正在使用redisAsyncConnect,并且我在断开连接时设置了回调。在回调中,我尝试重新连接与我在程序开始时使用的相同命令来建立连接,但它不起作用。似乎无法重新连接。
任何人都可以帮我一个例子吗?
我试图在断开连接时重新连接到Redis服务器。与hiredis重新连接
我正在使用redisAsyncConnect,并且我在断开连接时设置了回调。在回调中,我尝试重新连接与我在程序开始时使用的相同命令来建立连接,但它不起作用。似乎无法重新连接。
任何人都可以帮我一个例子吗?
当使用事件循环时,异步管理Redis(re)连接有点棘手。
下面是一个实现小型zset轮询守护程序的示例,该守护程序连接到Redis实例列表,这对于断开连接事件是有弹性的。使用ae事件循环(这是Redis自己使用的循环)。
http://gist.github.com/4149768
检查以下功能:
主要daemo只有当连接可用时,n循环才会执行其活动。每秒一次,第二次启动回调检查是否必须重新建立一些连接。我们发现这种机制相当可靠。
注意:为简洁起见,此示例中的错误管理很粗糙。真正的生产代码应该以更优雅的方式管理错误。
处理多个异步连接时的一个棘手问题是,没有用户定义的上下文数据作为相应回调的参数传递。在断开连接事件后清除与连接相关的数据可能有点困难。
感谢Didier,正是我所需要的。我想出了一些非常相似的东西,但是我没有将回调重新附加到事件循环中。不知道这是否是问题,因为还有其他差异,但您的示例非常有帮助。 – gkres
您可以查看redis Ruby gem代码并查看它的功能。有了宝石,如果有断开连接,下一个命令似乎可靠地重新建立连接。 – Gene