我想发布/生成一条带有一些消息 id 的消息,就像每条消息都有一个特定的 id 一样。
在消费者端,我想通过提供 ID 来检索消息。假设我们有多个消费者,而不是每个消费者应该只获得他们通过消息 ID 请求的那些消息。(我希望我足够清楚)。
我想发布/生成一条带有一些消息 id 的消息,就像每条消息都有一个特定的 id 一样。
在消费者端,我想通过提供 ID 来检索消息。假设我们有多个消费者,而不是每个消费者应该只获得他们通过消息 ID 请求的那些消息。(我希望我足够清楚)。
尽管它不是设计使然,最好使用数据库,但有一种方法可以使用rabbitmq:
发布带有 id 的消息:
var message = "some message";
var messageId = Guid.NewGuid().ToString();
var factory = new ConnectionFactory { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
IBasicProperties props = channel.CreateBasicProperties();
props.MessageId = messageId;
byte[] messageBodyBytes = Encoding.UTF8.GetBytes(message);
channel.BasicPublish("", "queueName", true, props, messageBodyBytes);
}
通过 id 获取消息:
var messageId = "id";
var factory = new ConnectionFactory { HostName = "localhost" };
using (var connection = _factory.CreateConnection())
using (var channel = connection.CreateModel())
{
var queueDeclareResponse = channel.QueueDeclare("queueName", true, true, false, null);
for (int i = 0; i < queueDeclareResponse.MessageCount; i++)
{
var result = channel.BasicGet("queueName", false);
var id = result.BasicProperties.MessageId;
if (id == messageId)
{
var body = result.Body;
var message = Encoding.UTF8.GetString(body);
//Do something with the message
channel.BasicAck(result.DeliveryTag, false);
break;
}
}
}
处理后channel
所有未确认的消息将重新排队。
为此,您最好使用数据库。
亚历克西斯 (rabbitmq)