Docker üzerinde Nginx Loadbalancer ile Deploy

Asp.net core ile geliştirdiğimiz uygulamaları docker ile deploy edip, nginx ile de load balance yapabiliriz.

İlk olarak asp.net core uygulamasını oluşturup, bu uygulamayı docker image haline getirmemiz gerekli.

mkdir coreapp
cd coreapp
dotnet new mvc

Uygulama bu hali ile çalışır haldedir. Docker image oluşturmak için projenin root klasöründe Dockerfile hazırlıyoruz.

FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443
FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /src
COPY corenginx.csproj ./
RUN dotnet restore "./corenginx.csproj"
COPY . .
WORKDIR "/src/."
RUN dotnet build "corenginx.csproj" -c Release -o /app/build
FROM build AS publish
RUN dotnet publish "corenginx.csproj" -c Release -o /app/publish
FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "corenginx.dll"]

Dockerfile dosyasını kullanarak docker image oluşturuyoruz.

docker build -t corenginx .

Artık docker image kullanarak istediğimiz kadar container açabiliriz.

docker run -d -p 5300:80 corenginx
docker run -d -p 5310:80 corenginx

http://localhost:5300 ve http://localhost:5310 adresini girip kontrol ettiğimizde çalışan uygulamaları göreceğiz. Artık nginx yapılandırmaya hazırız.

nginx ayar dosyamızı oluşturup nginx.conf olarak kaydediyoruz.

upstream servers {
     server 172.17.0.1:5300;
     server 172.17.0.1:5310;
}
server {
     listen 80;
     location / {
          proxy_pass http://servers;
     }
}

Docker image hazırlamak için dockerfile oluşturalım.

FROM nginx
RUN rm /etc/nginx/conf.d/default.conf
COPY nginx.conf /etc/nginx/conf.d
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]

Nginx için image dosyasını hazırlayalım.

docker build -t corebalance .

Bu sayede docker image hazır olmuş oluyor. Artık nginx container çalıştırıp sonucu görebiliriz.

docker run -d -p 80:80 corebalance

Örnek projeye https://github.com/oburan/DockerNginxLoadBalance adresinden ulaşabilirsiniz.