107 lines
3.9 KiB
Markdown
107 lines
3.9 KiB
Markdown
# Отчет по лабораторной работе №3
|
||
|
||
Выполнил студент гр. ИСЭбд-41 Мутрисков Д.С.
|
||
|
||
## REST API, Gateway и синхронный обмен между микросервисами
|
||
|
||
## Создание микросервисов
|
||
|
||
1. С помощью команды `dotnet new web -n worker-1` в терминале создал первый микросервис
|
||
2. Добавил решение командой `dotnet new sln`
|
||
3. Связал решение и проект командой `dotnet sln worker-1.sln add worker-1.csproj`
|
||
4. Повторил действие для второго микросервиса
|
||
5. Добавил библиотеку Swagger и OpenAi в проекты и запустил с помощью команды `dotnet run`
|
||
6. Заложил в приложения следующую логику :
|
||
|
||
worker-1 - CRUD для сущности Skill
|
||
|
||
worker-2 - CRUD для сущности Profession
|
||
|
||
К одной Profession относится много Skill
|
||
|
||
Скриншоты API обоих приложений:
|
||
![](images/SkillApi.png)
|
||
![](images/ProfessionApi.png)
|
||
|
||
## Реализация синхронного обмена
|
||
|
||
Реализовал простое хранилище, которое при инициализации обращается вызывает сихронно данные из соседнего микросервиса.
|
||
Далее эти данные используются при обработке запросов к API
|
||
|
||
```cs
|
||
public class Storage
|
||
{
|
||
public static Profession[] Professions { get; set; }
|
||
|
||
public static List<Skill> Skills { get; set; }
|
||
|
||
static Storage()
|
||
{
|
||
var client = new HttpClient();
|
||
string Url = "http://worker-2:80/Professions/";
|
||
Professions = client.GetFromJsonAsync<Profession[]>(Url).Result;
|
||
|
||
Skills = new List<Skill>()
|
||
{
|
||
new Skill() { Id = Guid.NewGuid(), Name = "Knowledge of programming", Level = Levels.Expert, ProfessionId = Professions.FirstOrDefault(p => p.Name == "Software Developer").Id },
|
||
new Skill() { Id = Guid.NewGuid(), Name = "Stress resistance", Level = Levels.Expert, ProfessionId = Professions.FirstOrDefault(p => p.Name == "Software Developer").Id },
|
||
new Skill() { Id = Guid.NewGuid(), Name = "The ability to cook", Level = Levels.Middle, ProfessionId = Professions.FirstOrDefault(p => p.Name == "Cook").Id },
|
||
new Skill() { Id = Guid.NewGuid(), Name = "Knowledge of plumbing", Level = Levels.Middle, ProfessionId = Professions.FirstOrDefault(p => p.Name == "Plumber").Id }
|
||
};
|
||
}
|
||
}
|
||
```
|
||
|
||
## Реализация gateway при помощи nginx
|
||
|
||
Добавил nginx.conf:
|
||
|
||
```conf
|
||
server {
|
||
listen 8080;
|
||
listen [::]:8080;
|
||
server_name localhost;
|
||
|
||
location / {
|
||
root /usr/share/nginx/html;
|
||
index index.html index.htm;
|
||
}
|
||
|
||
location /worker-1/ {
|
||
proxy_pass http://worker-1:80/;
|
||
proxy_set_header Host $host;
|
||
proxy_set_header X-Real-IP $remote_addr;
|
||
proxy_set_header X-Forwarded-Proto $scheme;
|
||
proxy_set_header X-Forwarded-Prefix /worker-1;
|
||
}
|
||
|
||
location /worker-2/ {
|
||
proxy_pass http://worker-2:80/;
|
||
proxy_set_header Host $host;
|
||
proxy_set_header X-Real-IP $remote_addr;
|
||
proxy_set_header X-Forwarded-Proto $scheme;
|
||
proxy_set_header X-Forwarded-Prefix /worker-2;
|
||
}
|
||
}
|
||
|
||
```
|
||
|
||
Результат, после выполнения команды `docker-compose up`:
|
||
|
||
Docker:
|
||
|
||
![](images/Docker.png)
|
||
|
||
index.html на gateway-1:
|
||
|
||
![](images/gateway.png)
|
||
|
||
|
||
worker-2:
|
||
|
||
![](images/professionResponse.png)
|
||
|
||
worker-2:
|
||
|
||
professionId - берется из другого приложения. Идентификаторы совпали -> все отработало корректно
|
||
![](images/skillsResponse.png) |