115 lines
3.2 KiB
Markdown
115 lines
3.2 KiB
Markdown
# Отчет по лабораторной работе №4
|
||
|
||
Выполнила студентка гр. ИСЭбд-41 Островская С. Ф.
|
||
|
||
## Прохождение tutorial
|
||
|
||
Установила rabbitMQ server, erlang и зашла в брокер под гостем по http://localhost:15672/#/
|
||
data:image/s3,"s3://crabby-images/da7b0/da7b0bda8544b62b08553d02627d8bec8c042826" alt=""
|
||
|
||
Туториал 1:
|
||
|
||
data:image/s3,"s3://crabby-images/5229a/5229a5c02d24ec8fdaee5bb04182040bab46f478" alt=""
|
||
data:image/s3,"s3://crabby-images/1e77b/1e77b1ab6eb8a24c583a257a62791788b90ede0c" alt=""
|
||
|
||
Туториал 2:
|
||
|
||
data:image/s3,"s3://crabby-images/5b907/5b9079a30892a320069f8c7584c0bafbde412ab5" alt=""
|
||
data:image/s3,"s3://crabby-images/f3b20/f3b202acc3bf9f35c71ab218e1b67188c99d38bf" alt=""
|
||
|
||
Туториал 3:
|
||
|
||
data:image/s3,"s3://crabby-images/e0552/e0552791f9e9b9bb8094f7cf67ce194c791f2a5d" alt=""
|
||
data:image/s3,"s3://crabby-images/e0b76/e0b76f1501ec7a8481720f196374c6a788ce7073" alt=""
|
||
|
||
## Разработка демонстрационных приложений
|
||
|
||
Предметная область: Дополнительный соглашения и договоры на проживание.
|
||
Разработаны три приложения, согласно предметной области.
|
||
|
||
1. Publisher
|
||
|
||
```py
|
||
import pika
|
||
import time
|
||
import random
|
||
|
||
collection = ["Application for accommodation in a dormitory", "Rector's order", "Conclusion of an agreement", "Check-into a dormitory"]
|
||
|
||
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/c4bf1/c4bf1cb8e10442164ae30e7fa636daf063c3f755" alt=""
|
||
data:image/s3,"s3://crabby-images/d815f/d815fed4e6ca8deb27f2a9452a2015ed33fae5dc" alt=""
|
||
|
||
Результат отработки Consumer_2:
|
||
|
||
data:image/s3,"s3://crabby-images/4fbc2/4fbc2ba53fb8f8417d2199e95d921ab9a124f15b" alt=""
|
||
data:image/s3,"s3://crabby-images/bb1e4/bb1e4b61a751d3282e6f4c3bda63a538282ef608" alt=""
|
||
|
||
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений. |