3

我正在使用 ActiveMQ 故障转移,例如

failover:(tcp://host1:61616,tcp://host2:61616)

我想在 host1 和 host2 都不可用时发出警报。

如果应用程序已经连接到代理,您可以通过 TransportListener 检测它何时进行故障转移。在初始连接期间也是不可能的。它只会挂起,反复重试每个代理。这是期望的行为,因为我希望它继续尝试连接,但是我也希望收到它有问题的通知,以便我可以发出警报,并且有人可以调查它。

一种解决方案是使用

failover:(tcp://host1:61616,tcp://host2:61616)?startupMaxReconnectAttempts=1

这意味着它将尝试每个主机然后抛出一个异常,我的应用程序可以通过警告然后再次尝试连接来处理它。这并不理想,因为我的应用程序必须有效地复制 ActiveMQ 重新连接逻辑。

有没有更好的方法来检测初始连接时的代理问题?

4

1 回答 1

3

简短的回答:不,没有办法从客户端(应用程序)启动的角度知道。

长答案:作为一个应用程序,您只会知道什么时候:您根本没有可用的代理(通过 startupMaxReconnectAttempts),或者您何时从一个代理切换到另一个代理。这是预期和期望的行为,因为故障转移机制的重点是对消费者隐藏所有这些。

可能有一些方法(例如使用动态代理网络),但这需要比您提出的解决方案更多的逻辑。

我认为您正在尝试使用错误的工具解决问题:使用故障转移机制(具有最大重新连接和适当的超时)只会确保您在出现真正错误时得到通知(根本没有可用的代理)。其他代理的“健康”或“连接”需要一个单独的机制(在系统级别 - 使用监控工具 - 或在应用程序级别 - 开发一个小机制来对 uri 列表中的所有代理进行保持活动)

于 2013-03-19T03:45:43.040 回答