163 lines
5.5 KiB
Markdown
163 lines
5.5 KiB
Markdown
# Отчёт по лабораторной работе №4
|
||
## Работа с брокером сообщений
|
||
|
||
Выполнила: студентка гр. ИСЭбд-41 Халитова А.М.
|
||
|
||
## Установка брокера сообщений RabbitMQ
|
||
Была выполнена установка RabbitMQ и Erlang:
|
||
data:image/s3,"s3://crabby-images/17c3e/17c3e7edcb62ad40efccaf9f04dce7067f1b6b2a" alt=""
|
||
data:image/s3,"s3://crabby-images/d823e/d823e2b9c6ab0153b357bd0160940ffe7bc271aa" alt=""
|
||
|
||
И выполнен вход на http://localhost:15672/ в качестве гостя:
|
||
data:image/s3,"s3://crabby-images/9ac44/9ac445796ccc5fcc68c97e53d38dfba5ec8d38f8" alt=""
|
||
|
||
## Прохождение tutorial
|
||
|
||
tutorial1:
|
||
data:image/s3,"s3://crabby-images/e2094/e2094a6fc7f20980d505f14740f7806e5f284781" alt=""
|
||
data:image/s3,"s3://crabby-images/0b1f8/0b1f86c6194312233e67f87478febb9ee4517860" alt=""
|
||
data:image/s3,"s3://crabby-images/5b2af/5b2af8fb47387513718df36917932ac977f6beb8" alt=""
|
||
|
||
tutorial2:
|
||
data:image/s3,"s3://crabby-images/004ea/004eac1454b320b08959eec60251a2190617e9c6" alt=""
|
||
data:image/s3,"s3://crabby-images/453a3/453a372e7b37c0f8e3b00cd467e21025367951a7" alt=""
|
||
data:image/s3,"s3://crabby-images/00676/00676a8c2a9ed86c108c847da1afa124c9e1c59d" alt=""
|
||
data:image/s3,"s3://crabby-images/6ee11/6ee115f821bf1b35ea87490e265154bfe0d98bbf" alt=""
|
||
|
||
tutorial3:
|
||
data:image/s3,"s3://crabby-images/d9862/d9862f8f076693c9a4c2746428d48f16999a9071" alt=""
|
||
data:image/s3,"s3://crabby-images/ca27f/ca27fbb57ad5d17b90ce00ccbde26a733f32ca5f" alt=""
|
||
data:image/s3,"s3://crabby-images/df5a6/df5a65d5d07e4eec39ffd02bd42b6ceb685756be" alt=""
|
||
|
||
## Разработка демонстрационных приложений
|
||
|
||
Предметная область - заказ работ на исполнение. Производитель - заказчик работ. Потребитель 1 - исполнитель принимает заказ и выполняет работу. Потребитель 2 - исполнитель откладывает выполнение задачи.
|
||
|
||
1. Publisher:
|
||
```
|
||
using System.Text;
|
||
using RabbitMQ.Client;
|
||
|
||
var factory = new ConnectionFactory { HostName = "localhost" };
|
||
using var connection = factory.CreateConnection();
|
||
using var channel = connection.CreateModel();
|
||
|
||
channel.ExchangeDeclare(exchange: "job", type: ExchangeType.Fanout);
|
||
Random rand = new Random();
|
||
foreach (var item in Enumerable.Range(0, 1000))
|
||
{
|
||
var message = rand.Next().ToString();
|
||
|
||
var body = Encoding.UTF8.GetBytes(message);
|
||
channel.BasicPublish(exchange: "job",
|
||
routingKey: string.Empty,
|
||
basicProperties: null,
|
||
body: body);
|
||
|
||
Console.WriteLine($" [x] Поступила работа {message}");
|
||
await Task.Delay(500);
|
||
}
|
||
|
||
Console.WriteLine(" Press [enter] to exit.");
|
||
Console.ReadLine();
|
||
|
||
static string GetMessage(string[] args)
|
||
{
|
||
return ((args.Length > 0) ? string.Join(" ", args) : "info: Принято!");
|
||
}
|
||
```
|
||
2. Consumer 1:
|
||
```
|
||
using System.Text;
|
||
using RabbitMQ.Client;
|
||
using RabbitMQ.Client.Events;
|
||
|
||
var factory = new ConnectionFactory { HostName = "localhost" };
|
||
using var connection = factory.CreateConnection();
|
||
using var channel = connection.CreateModel();
|
||
|
||
channel.QueueDeclare(queue: "accepted");
|
||
channel.QueueBind(queue: "accepted",
|
||
exchange: "job",
|
||
routingKey: string.Empty);
|
||
|
||
Console.WriteLine(" [*] Waiting for messages.");
|
||
|
||
var consumer = new EventingBasicConsumer(channel);
|
||
consumer.Received += async (model, ea) =>
|
||
{
|
||
byte[] body = ea.Body.ToArray();
|
||
var message = Encoding.UTF8.GetString(body);
|
||
|
||
string outputText = $"Работа принята к исполнению {message}";
|
||
Console.WriteLine($" [x] Done. {outputText}");
|
||
channel.BasicAck(deliveryTag: ea.DeliveryTag, multiple: false);
|
||
};
|
||
channel.BasicConsume(queue: "accepted",
|
||
autoAck: false,
|
||
consumer: consumer);
|
||
|
||
Console.WriteLine(" Press [enter] to exit.");
|
||
Console.ReadLine();
|
||
```
|
||
|
||
3. Consumer 3:
|
||
```
|
||
using System.Text;
|
||
using RabbitMQ.Client;
|
||
using RabbitMQ.Client.Events;
|
||
|
||
var factory = new ConnectionFactory { HostName = "localhost" };
|
||
using var connection = factory.CreateConnection();
|
||
using var channel = connection.CreateModel();
|
||
|
||
Random rand = new Random();
|
||
string queueName = $"denied{rand.Next()}";
|
||
|
||
channel.QueueDeclare(queue: queueName);
|
||
channel.QueueBind(queue: queueName,
|
||
exchange: "job",
|
||
routingKey: string.Empty);
|
||
|
||
Console.WriteLine(" [*] Waiting for messages.");
|
||
|
||
var consumer = new EventingBasicConsumer(channel);
|
||
consumer.Received += async (model, ea) =>
|
||
{
|
||
byte[] body = ea.Body.ToArray();
|
||
var message = Encoding.UTF8.GetString(body);
|
||
|
||
int waitTime = rand.Next(20, 90);
|
||
Thread.Sleep(waitTime * 100);
|
||
|
||
string outputText = $"Работа отложена {message} на {waitTime} минут";
|
||
Console.WriteLine($" [x] Done. {outputText}");
|
||
channel.BasicAck(deliveryTag: ea.DeliveryTag, multiple: false);
|
||
};
|
||
channel.BasicConsume(queue: queueName,
|
||
autoAck: false,
|
||
consumer: consumer);
|
||
|
||
Console.WriteLine(" Press [enter] to exit.");
|
||
Console.ReadLine();
|
||
```
|
||
|
||
## Результаты выполнения работ
|
||
|
||
Запуск каждой программы по одному экземпляру:
|
||
data:image/s3,"s3://crabby-images/1be51/1be512e6427890ef767336ca035114a13c08a80c" alt=""
|
||
data:image/s3,"s3://crabby-images/9edad/9edad9498de77758a7341347c4f8415cc9a04372" alt=""
|
||
data:image/s3,"s3://crabby-images/56db8/56db82b889669c637fdc22b02d8cec2f6d7abad5" alt=""
|
||
|
||
Результаты обработки:
|
||
data:image/s3,"s3://crabby-images/d2107/d21070ef39d72641e6acf5cd82ca34ef80db0e68" alt=""
|
||
data:image/s3,"s3://crabby-images/71f2d/71f2de61ce75285ce973bcfd9fb8eaa0464aa5f6" alt=""
|
||
|
||
Потребителю один соответствует очередь accepted, а потребителю два - очередь denied. Как видно, первый потребитель работает без задержки, а очередь второго потребителя переполенена. Из этого следует, что скорость первого в разы выше, и он потребляет намного меньше памяти за счет постоянно пустой очереди.
|
||
|
||
Запуск двух экземпляров потребителя два и по одному экземпляру потребителя один и заказчика:
|
||
data:image/s3,"s3://crabby-images/48ec0/48ec02e28e02a1a0ae6987a29b4f04f20fc11071" alt=""
|
||
data:image/s3,"s3://crabby-images/ab3a8/ab3a8c03e58422504e8e4620370fdce01ba777e3" alt=""
|
||
|
||
Ситуация в очередью потребителя один не изменилась, а экземпляры потребителя два теперь затрачивают в 2 раза больше времени и памяти, их очереди так же переполнены, как и в ситуации выше.
|