我们在测试环境中配置了RabbitMQ的主动/主动群集.
我们使用指定ReceiveFrom的MassTransit进行连接(“rabbitmq:// cluster_machine_a / some_queue?ha = true”).
显然,这是利用特定的集群节点,因此不提供故障转移.
通知MassTransit有关群集节点的正确方法是什么,以便发生故障转移?
RabbitMQ文档表明客户端应该使用传统的负载均衡器来管理流量,但这是否适用于RabbitMQ? (最后一节 – http://www.rabbitmq.com/clustering.html)
最佳答案 为了回答我自己的问题,在MassTransit中没有故障转移a-la SQL服务器连接字符串与故障转移伙伴的概念.
相反,您只需在RMQ的前面引入负载均衡器,并接受在节点发生故障时您将收到错误,您需要对其进行代码恢复.当然,您需要将RMQ节点连接在一起,这可以通过内置的群集实现.
最后,从负载均衡器引入的虚拟IP接收,让它负责检测失败的RMQ节点.