# Отчёт по лабораторной работе №4 Выполнил: студент гр. ИСЭбд-41 Михайлов Ю.С. ## Прохождение туториалов Установил RabbitMQ, Erlang и зашел в брокер под гостем по адресу http://localhost:15672/#/ Туториал 1: data:image/s3,"s3://crabby-images/7c107/7c1071f6bc4ae649a4f2f81ab5cc9e616f5fe02a" alt="" data:image/s3,"s3://crabby-images/4103c/4103c725ebfe9801b6e5cd1d083676d1c18d06e8" alt="" data:image/s3,"s3://crabby-images/17913/17913b40ceb9c5f9c613f616ea3371fc1407da9f" alt="" Туториал 2: data:image/s3,"s3://crabby-images/ef352/ef35255dbe4f49966164743fbdc05a29eff82ec4" alt="" data:image/s3,"s3://crabby-images/84b3a/84b3a5c0079b54a41743205f36389d5b55470034" alt="" data:image/s3,"s3://crabby-images/838eb/838eb7dd62fdbd6e784f1ef89a031a9ebfc19ec8" alt="" data:image/s3,"s3://crabby-images/f4a86/f4a860672f23be0b18337625b35fb38252566b65" alt="" Туториал 3: data:image/s3,"s3://crabby-images/67276/672761eb158c6a9d43bc3c4b7d0e527a6ec685e7" alt="" data:image/s3,"s3://crabby-images/007ee/007eeab198f65293d53f03ddc8bd84a8cd390ba8" alt="" data:image/s3,"s3://crabby-images/814a8/814a83d0e92e6593fabb98cf1b2aafff649e2f75" alt="" ## Разработка демонстрационных приложений Предметная область - оформление заявлений на стипендию в университете. Разработано три приложения согласно предметной области. 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: "report", 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: "report", 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: "report", 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: "report", 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/96f75/96f756e9e00e066f203efe67f538acda001b608d" alt="" data:image/s3,"s3://crabby-images/34c96/34c96c1c43e86e0c9a72881c92e130b0666f4b8f" alt="" data:image/s3,"s3://crabby-images/6f227/6f2276fed6166187e2265eb07383ef1362f5f7aa" alt="" Результаты обработки: data:image/s3,"s3://crabby-images/d14e0/d14e022fda583888be0971aa3242d2d29ac6f81d" alt="" data:image/s3,"s3://crabby-images/f0c99/f0c99e5bf0e3abfcee203dfdb31ee8daca479def" alt="" Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений