首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >部署RabbitMQ HA以避免丢失消息

部署RabbitMQ HA以避免丢失消息
EN

Stack Overflow用户
提问于 2017-03-09 01:50:13
回答 1查看 191关注 0票数 1

我使用以下策略在2个节点上设置了一个带有消息镜像的3节点RabbitMQ集群:

代码语言:javascript
复制
ha-mode: exactly
ha-params: 2
ha-sync-mode: automatic

我正在使用Spring Boot和Spring AMQP做一些性能测试。基本上,我让Apache向发布消息的控制器发送JMeter请求:

代码语言:javascript
复制
@RequestMapping(value = "/webhook", method = RequestMethod.POST)
public void webhook(@RequestBody(required = true) String webhookBody, HttpServletRequest request) {
        rabbitTemplate.convertAndSend("exchange", "key", "message");
}

配置如下:

代码语言:javascript
复制
spring:    
  rabbitmq:
    addresses: rabbitmq-1:5672,rabbitmq-2:5672,rabbitmq-3:5672

我将脚本配置为每隔100ms执行一次请求,并在运行时尝试关闭一个节点。结果是AutoRecoverConnectionNotCurrentlyOpenException和至少8-9个失败的请求。在这种情况下,您建议使用哪些其他设置来完全避免失败的响应?使用像HAProxy / Nginx这样的第四层代理更好吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-09 02:30:58

在底层的兔连接工厂上重置autoRecoverEnabled (在1.7.0中默认值为真);在1.7.1中默认为false。

RabbitTemplate将比客户端的autoRecovery机制更快地恢复连接。

但是,为了避免消息丢失,您可能需要考虑向RabbitTemplate添加一个RetryTemplate

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42678409

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档