2023-12-18 16:44:22 +04:00
# Отчет по лабораторной работе №4
Выполнил студент г р . ИСЭбд-41 Дунаев О .И.
## Прохождение tutorial
Установил rabbitMQ server, erlang и зашел в брокер под гостем по http://localhost:15672/#/
Туториал 1:
data:image/s3,"s3://crabby-images/72534/7253402929ef17c3b44281edaec65e7ece71b224" alt=""
data:image/s3,"s3://crabby-images/076ab/076abde0d8ece18e550d51647aa9be6f60fa9713" alt=""
data:image/s3,"s3://crabby-images/02b56/02b561f30f2f2c6a0e11a5ac99bf974bebf85972" alt=""
Туториал 2:
data:image/s3,"s3://crabby-images/c92ce/c92cee0e48aa80323ab304943e44f15b990f8ce7" alt=""
data:image/s3,"s3://crabby-images/f5b8d/f5b8dbf3b8f7e9fa003829a702867d9ad1a0ade9" alt=""
data:image/s3,"s3://crabby-images/3086c/3086c01b4c84b0a025973a4b6abbed810c33313f" alt=""
Туториал 3:
data:image/s3,"s3://crabby-images/3e326/3e3266ad296c0e340923369b22e6540f555bd57d" alt=""
data:image/s3,"s3://crabby-images/57ad6/57ad6a7a6ed4ff0f042118a879740bd88fddd141" alt=""
2023-12-21 00:43:09 +04:00
data:image/s3,"s3://crabby-images/c70ee/c70ee7d9edf23060a46a5e0fdf5519ee0e502842" alt="".
2023-12-18 16:44:22 +04:00
## Разработка демонстрационных приложений
Предметная область: Дополенительные соглашения и договора на заселение в отель Туристического агентства.
Разработа три приложения согласно предметной области.
1. Publisher
```py
import pika
import time
import random
collection = ["Application for Travel Agency", "Buying tickets", "Execution of the agreement", "Check-into a hotel"]
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:
data:image/s3,"s3://crabby-images/157f4/157f43e0b2e49161b200e20fef967ac323d11095" alt=""
Результат отработки Consumer_2:
data:image/s3,"s3://crabby-images/f6426/f6426b240b2c966e84edc92196676c4480b8cdb7" alt=""
data:image/s3,"s3://crabby-images/e7e71/e7e71c1fa487d0476a8ba2b33c72d70dd18240bc" alt=""
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений.