RabbitMQ 使用QOS(服务质量)+Ack机制解决内存崩溃的情况

当消息有几万条或者几十万条的时候,如果消费的方式不对,会造成内存崩溃的情况

一:consumer

1. 短链接:basicget 独自去获取message。。。 request 的方式去获取,断开式。。。

 

2. 长连接:eventbasicconsumer。。。 【订阅式】


1. eventbasicconsumer + noack....

consumer端处理一条数据需要耗费 1s钟。。。。

《1》 确认机制。。。 不管你是否却不确认,消息都会一股脑全部打入到你的consumer中去。。。

《2》 QOS =》 服务质量。。。 【QOS + Ack】机制,解决这个问题。。。
我希望是一条一条从broke中打过来。。。

解决办法就是在channel设置好通道。。。

channel.BasicQos(0, 1, false);这样RabbitMQ就会使得每个Consumer在同一个时间点最多处理一个Message。换句话说,在接收到该Consumer的ack前,他它不会将新的Message分发给它。
EventingBasicConsumer consumer = new EventingBasicConsumer(channel);

consumer.Received += (sender, e) =>
{
var msg = Encoding.UTF8.GetString(e.Body);

Console.WriteLine(msg);
};

channel.BasicConsume("mytest", true, consumer);


eventbasicconsumer : noack=true, 直连 =》 会造成application内存暴涨 + 可能丢失数据【application挂了】

noack=false, 直连 =》 造成【application】可能会挂掉。。

noack + QOS 直连 =》 没问题。。。 【我们可以想象的】

 

BasicGet: 获取redis中的操作模式是一样的。。。。
不利的地方,就是每次都会创建一个channel。。。。 【最安全 + 性能不算太差】

转载于:https://www.cnblogs.com/yxlblogs/p/10253609.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值