2023-12-16 20:09:40 +04:00
# Отчет по лабораторной работе №4
Выполнила студентка г р . ИСЭбд-41 Зиновьева А . Д.
## Прохождение tutorial
Установила rabbitMQ server, erlang и зашла в брокер под гостем по http://localhost:15672/#/
data:image/s3,"s3://crabby-images/506cd/506cd50f7940ef3b59d839e4a42e02d0d08963f6" alt=""
Туториал 1:
data:image/s3,"s3://crabby-images/e2988/e298864c1cb1eb8e0d2c95f8b9a731784fe60bf4" alt=""
data:image/s3,"s3://crabby-images/ad76b/ad76bf9b45ddcc59a2a3432c1429a2c4867efb54" alt=""
data:image/s3,"s3://crabby-images/1b170/1b170e558812e2b6b4a2810656f5b29eb35cb3a0" alt=""
Туториал 2:
data:image/s3,"s3://crabby-images/7e58b/7e58bb4916b6a64728d160c02a696afef7cfc74e" alt=""
data:image/s3,"s3://crabby-images/fae1f/fae1fd08b4e2a061c2efefa49279cc0917919888" alt=""
data:image/s3,"s3://crabby-images/03288/032888228511f55a8892b08b6b6b59afabbd2ff6" alt=""
Туториал 3:
data:image/s3,"s3://crabby-images/ef8a7/ef8a725bece72d32bd067fcfea011a316e3c2139" alt=""
data:image/s3,"s3://crabby-images/df767/df767042daf07e13ea64b806e3a7e7fb4e2c0e4c" alt=""
data:image/s3,"s3://crabby-images/06d77/06d7738bb53fd96b22a1d2b1a399b513cbb5266e" alt=""
## Разработка демонстрационных приложений
Предметная область: Дополнительный соглашения и договоры на проживание.
Разработаны три приложения, согласно предметной области.
1. Publisher
```py
import pika
import time
import random
2023-12-16 21:04:41 +04:00
collection = ["the employment document", "The document is agreed", "Signatures are provided", "the employee is accepted"]
2023-12-16 20:09:40 +04:00
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.exchange_declare(exchange='Agreements', exchange_type='fanout')
while True:
message = f"Message: {random.choice(collection)}"
channel.basic_publish(exchange='Agreements', routing_key='', body=message)
time.sleep(1)
connection.close()
```
2. Consumer 1.
```py
import pika
import time
def process_message(ch, method, properties, body):
print(f"Получено сообщение: {body}")
time.sleep(3)
print("Сообщение успешно обработано")
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
result = channel.queue_declare(queue='', exclusive=True)
queue_name = result.method.queue
channel.queue_bind(exchange='Agreements', queue=queue_name)
channel.basic_consume(queue=queue_name, on_message_callback=process_message, auto_ack=True)
print('Ожидание сообщений...')
channel.start_consuming()
```
3. Consumer 2.
```py
import pika
def process_message(ch, method, properties, body):
print(f"Получено сообщение: {body}")
print("Сообщение успешно обработано")
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
result = channel.queue_declare(queue='', exclusive=True)
queue_name = result.method.queue
channel.queue_bind(exchange='Agreements', queue=queue_name)
channel.basic_consume(queue=queue_name, on_message_callback=process_message, auto_ack=True)
print('Ожидание сообщений...')
channel.start_consuming()
```
## Результаты выполнения лабораторной работы
Результат отработки Consumer_1:
2023-12-16 21:04:41 +04:00
data:image/s3,"s3://crabby-images/7941f/7941faff0fb0406f5eededd099ef6adde7611c3a" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/ec62a/ec62a1abc6c8930ec47f7737eb7cde1ebeb0200e" alt=""
Результат отработки Consumer_2:
2023-12-16 21:04:41 +04:00
data:image/s3,"s3://crabby-images/17edf/17edf492f17b7708ab636bab0e76a095fe384dfd" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/767d7/767d7c94e80bdccdcbe6931ce927f91567e1bcb6" alt=""
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений.