Sobes.tech
Back to questions
Junior — Middle
67

Каким образом осуществляется доставка сообщений к нескольким подписчикам в системе RabbitMQ?

Companies where asked
Медиалогия

Answer from AI

sobes.tech AI

В RabbitMQ доставка сообщений нескольким подписчикам реализуется через обменники типа "fanout". Такой обменник рассылает каждое полученное сообщение всем очередям, которые к нему привязаны. Таким образом, каждый подписчик, слушающий свою очередь, получит копию сообщения.

Пример на C# с использованием библиотеки RabbitMQ.Client:

var factory = new ConnectionFactory() { HostName = "localhost" };
using var connection = factory.CreateConnection();
using var channel = connection.CreateModel();

channel.ExchangeDeclare(exchange: "logs", type: ExchangeType.Fanout);

var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queue: queueName, exchange: "logs", routingKey: "");

var consumer = new EventingBasicConsumer(channel);
consumer.Received += (model, ea) => {
    var body = ea.Body.ToArray();
    var message = Encoding.UTF8.GetString(body);
    Console.WriteLine("Received: " + message);
};
channel.BasicConsume(queue: queueName, autoAck: true, consumer: consumer);

Здесь каждый подписчик создает свою очередь и привязывает её к fanout-обменнику, получая все сообщения.