1

我正在尝试在断开连接时重新连接到 Redis 服务器。

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

谁能帮我举个例子?

4

1 回答 1

3

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

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

http://gist.github.com/4149768

检查以下功能:

  • 连接回调
  • 断开回调
  • 检查连接
  • 如果需要重新连接

仅当连接可用时,主守护程序循环才会执行其活动。每秒一次,第二次发起的回调检查是否必须重新建立某些连接。我们发现这种机制非常可靠。

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

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

于 2012-11-26T19:17:05.047 回答