我们一般使用的是消费者作为被动方接收 RabbitMQ 推送消息,另一种是消费者作为主动方可以主动拉取消息。
RabbitMq 服务器推送消息分为隐式(自动)确认和显示确认。
1 消费者拉取消息
消费者作为主动方拉取消息,每次只能获取一条。
using (var channel = connection.CreateModel())
{
BasicGetResult result = channel.BasicGet("PersistenceQueue", true);
string message = Encoding.UTF8.GetString(result.Body.ToArray());
Console.WriteLine($"拉取到消息:{message}");
}
2 RabbitMq服务器推送消息
消费者作为被动方接收RabbitMQ推送消息。
using (var channel = connection.CreateModel())
{
EventingBasicConsumer consumer = new EventingBasicConsumer(channel);
//就是Rabbitmq的服务器作为主动方---RabbitMq 推送消息到消费者来的;
consumer.Received += (model, ea) =>
{
string message = Encoding.UTF8.GetString(ea.Body.ToArray());
Console.WriteLine($"正常收到消息:{message}");
};
channel.BasicConsume(queue: "PersistenceQueue", autoAck: true, consumer: consumer);
}
3 隐式确认
当 RabbbitMQ 将消息发送给消费者后,消费者端接收到消息后,不等待消息处理结束,立即自动回送一个确认回执。
自动确认的用法十分简单,设置消费方法的参数 autoAck 为 true 即可,我们前边的例子都是使用的自动确认。
channel.BasicConsume(queue: "PersistenceQueue", autoAck: true, consumer: consumer);
4 显式确认
设置消费方法的参数 autoAck 为 false,channel.BasicAck可以一条一条确认后删除,也可使用 channel.BasicReject不删除。
//定义消费者
EventingBasicConsumer consumer = new EventingBasicConsumer(channel);
int i = 0;
//就是Rabbitmq的服务器作为主动方---RabbitMq 推送消息到消费者来的;
consumer.Received += (model, ea) =>
{
string message = Encoding.UTF8.GetString(ea.Body.ToArray());
Console.WriteLine($"正常收到消息:{message}");
if (i < 100)
{
Console.WriteLine($"【{message}】消息已经被消费,同时从RabbitMQ服务器删除");
channel.BasicAck(deliveryTag: ea.DeliveryTag, multiple: false);
}
else
{
Console.WriteLine($"【{message}】消息没有被正常消费,可以让消息不要删除");
channel.BasicReject(deliveryTag: ea.DeliveryTag, requeue: true);
//throw new Exception("消息消费异常了~");
}
i++;
};
//显式确认
channel.BasicConsume(queue: "PersistenceQueue", autoAck: false, consumer: consumer);
5 消息质量
channel.BasicQos可以设置每次从队列中取出几条消息进行消费。
channel.BasicQos(prefetchSize: 0, prefetchCount: 2, global: false);
方法中参数 prefetchSize 为预取的长度,一般设置为0即可,表示长度不限;
prefetchCount 表示预取的条数,即发送的最大消息条数;
global 表示是否在 Connection 中全局设置,true表示 Connetion 下的所有 channel 都设置为这个配置。
标签:消费,ea,确认,RabbitMQ,消息,message,consumer,channel From: https://www.cnblogs.com/nullcodeworld/p/18669523