.. | ||
pic | ||
static | ||
worker-1 | ||
worker-2 | ||
.gitignore | ||
docker-compose.yml | ||
nginx.conf | ||
README.md |
Отчет по лабораторной работе №3
Выполнил студент гр. ИСЭбд-41 Савицкий А.В.
REST API, Gateway и синхронный обмен между микросервисами
Создание микросервисов
-
С помощью команды
dotnet new web -n worker-1
в терминале создал первый микросервис -
Добавил решение командой
dotnet new sln
-
Связал решение и проект командой
dotnet sln worker-1.sln add worker-1.csproj
-
Повторил действие для второго микросервиса
-
Добавил библиотеку Swagger и OpenAi в проекты и запустил с помощью команды
dotnet run
-
Заложил в приложения следующую логику :
worker-1 - CRUD для сущности Aeroplan
worker-2 - CRUD для сущности Pilot
К одному Aeroplan относится много Pilot
Скриншоты API обоих приложений:
Реализация синхронного обмена
Реализовал хранение данных в оперативной памяти с хранилещем спректированым по паттерну Singleton. Хранилище при инициализации сихронно вызывает данные из соседнего микросервиса. Далее эти данные используются при обработке запросов к API
public class Storage
{
private static Random rand = new Random();
public AiroplaneDal[] Airoplanes { get; set; }
public List<PilotDal> Pilots { get; set; }
public static Storage Instance { get; set; }
private Storage() { }
public static async Task<Storage> GetInstance()
{
if(Instance is not null)
{
return Instance;
}
var client = new HttpClient();
string reqUrl = $"http://worker-1:8080/Aeroplanes/";
Instance = new Storage();
Instance.Airoplanes = await client.GetFromJsonAsync<AiroplaneDal[]>(reqUrl);
Instance.Pilots = new List<PilotDal>()
{
new PilotDal() { PilotId = Guid.NewGuid(), BirthDate = DateTime.Today.AddDays(-100), AeroplaneId = Instance.Airoplanes[rand.Next(Instance.Airoplanes.Length)].AeroplaneId, FullName = "Савицкий Александр Вячеславович", Experience = 10 },
new PilotDal() { PilotId = Guid.NewGuid(), BirthDate = DateTime.Today.AddDays(-150), AeroplaneId = Instance.Airoplanes[rand.Next(Instance.Airoplanes.Length)].AeroplaneId, FullName = "Гайдулян Максим Петрович", Experience = 15 }
};
return Instance;
}
}
Реализация gateway при помощи nginx
Добавил nginx.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:8080/;
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:8080/;
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:
index.html на localhost:8080:
worker-1:
worker-2: companyId - берется из другого приложения. Идентификаторы совпали -> все отработало корректно