rabbitmq 开发过程中会出现的问题

本文总结了在使用RabbitMQ过程中遇到的一些问题及其解决策略,包括连接异常、消息丢失、数据文件路径、消息乱序、队列堵塞和死循环等问题,提供了详细的解决方法和配置示例。
摘要由CSDN通过智能技术生成

rabbitmq_坑

None of the specified endpoints were reachable

异常:

1、unable to connect to node rabbit@10: nodedown

2、Message:Already closed: The AMQP operation was interrupted: AMQP close-reason, initiated by Peer, code=320, text="CONNECTION_FORCED - broker forced connection closure with reason 'shutdown'", classId=0, methodId=0, cause= StackTrace

3、Rabbitmq实际数据文件、日志文件、配置文件路径

RabbitMQ消息丢失以及解决策略

消息丢失

RabbitMQ流程

producer端

RabbitMQ Server端

Consumer端

消息乱序

RabbitMQ的ack或nack机制使用不当导致的队列堵塞或死循环问题

自动ack机制会导致消息丢失的问题;

启用ack机制后,没有及时ack导致的队列异常;

启用nack机制后,导致的死循环

启用Qos和ack机制后,没有及时ack导致的队列堵塞;

消费者串行处理,崩溃时导致未处理的预取数据丢失;

心跳时间设置太短导致的异常;

rabbitmq_坑
None of the specified endpoints were reachable
这个异常在创建连接时抛出(CreateConnection()),原因一般是ConnectionFactory参数设置不对,比如HostName、UserName、Password

标准设置:

var factory = new ConnectionFactory();

factory.UserName = QueueSetttiong.UserName;   //用户名

factory.Password = QueueSetttiong.Password;      //密码

factory.HostName = QueueSetttiong.HostName;  //Rabbitmq服务IP,不包含端口

factory.Port = AmqpTcpEndpoint.UseDefaultPort;

factory.VirtualHost = QueueSetttiong.VirtualHost;  //默认为"/"

factory.Protocol = Protocols.DefaultProtocol;

部署生产后,factory配置都ok,但是还是抛异常None of the specified endpoints were reachable,最后发现原因是生产机器防火墙未打开RabbitMQ的端口,RabbitMQ的默认端口是:5672

另外一个可能的原因:未设置VirtualHost的权限

设置方法:RabbitmqWeb管理网站-->Admin

未设置权限时:

设置权限:(点击admin进入设置页面)

异常:
1、unable to connect to node rabbit@10: nodedown
重新安装Rabbitmq服务端即可,有时候需要重启

2、Message:Already closed: The AMQP operation was interrupted: AMQP close-reason, initiated by Peer, code=320, text="CONN

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值