52 lines
3.2 KiB
Markdown
52 lines
3.2 KiB
Markdown
|
||
# Лабораторная работа №3 - REST API, шлюз и синхронный обмен данными между микросервисами
|
||
|
||
## Задание
|
||
|
||
### Цель
|
||
Изучение принципов проектирования с использованием паттерна шлюза, организации синхронной передачи данных между микросервисами и применения архитектурного стиля RESTful API.
|
||
|
||
### Задачи
|
||
1. Создание двух микросервисов, которые реализуют операции CRUD для связанных сущностей.
|
||
2. Реализация механизма синхронного обмена данными между микросервисами.
|
||
3. Настройка шлюза на базе Nginx в качестве прозрачного прокси-сервера.
|
||
|
||
### Микросервисы
|
||
1. **user_service** — сервис, который управляет информацией о пользователях.
|
||
2. **order_service** — сервис, который обрабатывает данные о заказах пользователей.
|
||
|
||
### Связь между микросервисами
|
||
- Один документ (user) может иметь множество связанных предметов (orders) (соотношение 1 ко многим).
|
||
|
||
### Структура проекта
|
||
|
||
```
|
||
lab_3/
|
||
|-- nginx/
|
||
| |-- nginx.conf
|
||
|-- order_service/
|
||
| |-- Dockerfile
|
||
| |-- main.py
|
||
| |-- requirements.txt
|
||
|-- user_service/
|
||
| |-- Dockerfile
|
||
| |-- main.py
|
||
| |-- requirements.txt
|
||
|-- docker-compose.yml
|
||
```
|
||
|
||
## Описание работы:
|
||
|
||
Для разработки микросервисов был выбран язык программирования Python.
|
||
|
||
### Синхронный обмен данными
|
||
Сервис `user_service` отправляет HTTP-запросы к `order_service` при выполнении определенных операций CRUD. Это позволяет получать актуальную информацию о предметах, связанных с конкретными героями.
|
||
|
||
### Docker Compose
|
||
Конфигурационный файл `docker-compose.yml` представляет собой многоконтейнерное приложение, которое включает в себя три сервиса: `user_service`, `order_service` и `nginx`. Функция маршрутизации возложена на сервер Nginx, который обрабатывает запросы и перенаправляет их на соответствующие микросервисы.
|
||
|
||
### Nginx
|
||
Конфигурационный файл Nginx определяет настройки веб-сервера и обратного прокси, который управляет входящими запросами и направляет их на соответствующие сервисы.
|
||
|
||
### Видеозапись работы программы доступна по ссылке
|
||
https://cloud.mail.ru/public/dEYz/J7wbFPijE |