distributed-computing/tasks/klementeva-ja/lab_3/README.md
2023-12-16 11:48:57 +04:00

2.7 KiB
Raw Blame History

Отчет по лабораторной работе №3 REST API, Gateway и синхронный обмен между микросервисами

Выполнила студентка гр. ИСЭбд-41 Клементьева Ж.А.

Создание микросервисов

Создание микросервисов было реализовано следующим образом:

  1. С помощью команды dotnet new web -n worker-2 в терминале создала первый микросервис, где решение добавила командой dotnet new sln.
  2. Также использовала данную команду: dotnet sln worker-2.sln add worker-2.csproj с целью связки решения и проекта.
  3. Аналогичные действия были совершены со вторым микросервисом.
  4. Были добавлены библиотеки Swagger и OpenAi в проекты.
  5. Также проект был запущен с помощью команды dotnet run.

Скриншоты микросервисов worker 1 и worker 2:

Путь localhost:8080:

Синхронный обмен

Также мною был реализован код, вызывающий сихронно данные из соседнего микросервиса.

//worker-2
app.MapGet("/Requests/", async () =>
{
    var httpClient = new HttpClient();
    var secondWorkerResponse = await httpClient.GetStringAsync("http://worker-1:8080/");

    return secondWorkerResponse.ToArray();
})
.WithName("GetRequests")
.WithOpenApi();

Реализация 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 были получены такие результаты:

Результат worker1: Результат worker2: