48 lines
1.6 KiB
C#
48 lines
1.6 KiB
C#
using System;
|
|
using RabbitMQ.Client;
|
|
using RabbitMQ.Client.Events;
|
|
using System.Text;
|
|
|
|
class ReceiveLogsTopic
|
|
{
|
|
public static void Main(string[] args)
|
|
{
|
|
var factory = new ConnectionFactory() { HostName = "localhost" };
|
|
using(var connection = factory.CreateConnection())
|
|
using(var channel = connection.CreateModel())
|
|
{
|
|
channel.ExchangeDeclare(exchange: "topic_logs", type: "topic");
|
|
var queueName = channel.QueueDeclare().QueueName;
|
|
|
|
if (args.Length < 1)
|
|
{
|
|
Console.Error.WriteLine("Usage: {0} [binding_key...]", Environment.GetCommandLineArgs()[0]);
|
|
Console.WriteLine(" Press [enter] to exit.");
|
|
Console.ReadLine();
|
|
Environment.ExitCode = 1;
|
|
return;
|
|
}
|
|
|
|
foreach(var bindingKey in args)
|
|
{
|
|
channel.QueueBind(queue: queueName, exchange: "topic_logs", routingKey: bindingKey);
|
|
}
|
|
|
|
Console.WriteLine(" [*] Waiting for messages. To exit press CTRL+C");
|
|
|
|
var consumer = new EventingBasicConsumer(channel);
|
|
consumer.Received += (model, ea) =>
|
|
{
|
|
var body = ea.Body.ToArray();
|
|
var message = Encoding.UTF8.GetString(body);
|
|
var routingKey = ea.RoutingKey;
|
|
Console.WriteLine(" [x] Received '{0}':'{1}'", routingKey, message);
|
|
};
|
|
channel.BasicConsume(queue: queueName, autoAck: true, consumer: consumer);
|
|
|
|
Console.WriteLine(" Press [enter] to exit.");
|
|
Console.ReadLine();
|
|
}
|
|
}
|
|
}
|