Docker üzerinde MS Sql Server Kurulumu

Docker ile Microsoft Sql Server çalıştırmak için aşağıdaki adımları takip edebilirsiniz.

sudo docker pull mcr.microsoft.com/mssql/server:2019-latest
sudo docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=Sifre0134" -p 1433:1433 --name mssql -h mssql -d mcr.microsoft.com/mssql/server:2019-latest

Sql Server kurulumu tamamlanmış oldu. Mac işletim sistemi için Azure Data Studio uygulamasını indirip localhost olarak bağlantı sağlayabilirsiniz.

Backup dosyasını geri yüklemek için ilk önce backup dosyasını container içine kopyalanması gerekli.

sudo docker exec -it mssql mkdir /var/opt/mssql/backup
sudo docker cp kaynak/dosyaadi.bak mssql:/var/opt/mssql/backup

Azure Data Studio uygulamasını kullanarak yüklendiğiniz backup dosyasını restore edebilirsiniz.

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.

Ubuntu ile ASP.NET Core 3 Deployment

ASP.NET Core 3 ile geliştirilmiş web uygulamalarını Linux ortamında çalıştırabiliyoruz.

İlk olarak Ubuntu sunucumuzu dotnet core yüklemek gerekli.

wget https://packages.microsoft.com/config/ubuntu/20.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb

sudo dpkg -i packages-microsoft-prod.deb
sudo apt-get update
sudo apt-get install -y apt-transport-https
sudo apt-get update
sudo apt-get install -y aspnetcore-runtime-3.1

Artık sunucuda dotnet core çalışır halde. Web sunucu olarak nginx kullanacağız.

sudo apt-get install nginx

Nginx reverse-proxy olarak web uygulamasını yayınlacak. Bu nedenle Nginx üzerinde aşağıdaki ayarları yapmak gerekiyor.

sudo nano /etc/nginx/sites-available/default

server {
        listen 80 default_server;
        server_name _;
        return 444;
}
server {
        listen 80;
        server_name siteadi.com;
        location / {
                proxy_pass         http://localhost:5000;
                proxy_http_version 1.1;
                proxy_set_header   Upgrade $http_upgrade;
                proxy_set_header   Connection keep-alive;
                proxy_set_header   Host $host;
                proxy_cache_bypass $http_upgrade;
                proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header   X-Forwarded-Proto $scheme;
        }
}

sudo service nginx stop
sudo service nginx start

Artık 80 nolu porttan siteadi.com olarak gelen istekleri nginx 5000 nolu porta yönlendirmiş olacak.

Optimal nginx ayarları için aşağıdaki bilgiler kullanılabilir.

sudo nano /etc/nginx/nginx.conf
user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;
events {
        worker_connections 8000;
        accept_mutex    off;
}
http {
        sendfile on;
        tcp_nopush on;
        tcp_nodelay off;
        keepalive_timeout 29;
        client_body_timeout     10;
        client_header_timeout   10;
        send_timeout            10;
        limit_req_zone          $binary_remote_addr zone=one:10m rate=5r/s;
        server_tokens           off;
        types_hash_max_size 2048;
        include /etc/nginx/mime.types;
        default_type application/octet-stream;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; 
        ssl_prefer_server_ciphers on;
        access_log /var/log/nginx/access.log;
        error_log /var/log/nginx/error.log;
        add_header X-Content-Type-Options "nosniff";
        add_header X-Frame-Options "SAMEORIGIN";
        gzip on;
        gzip_comp_level         9;
        gzip_http_version       1.0;
        gzip_disable            "MSIE [1-6]\."
        gzip_vary on;
        # gzip_proxied any;
        gzip_types text/plain 
                text/css 
                application/json 
                application/javascript
                text/xml 
                application/xml 
                application/xml+rss 
                text/javascript
                application/manifest+json 
                application/x-web-app-manifest+json
                text/cache-manifest 
                font/opentype 
                font/otf 
                font/truetype
                application/font-woff 
                application/vnd.ms-fontobject 
                image/svg+xml;
        include /etc/nginx/conf.d/*.conf;
        include /etc/nginx/sites-enabled/*;
}

Yayınlancak web uygulamasını /var/www klasörünü altında alt klasör açarak yayınlayabiliriz.

Uygulamanın sürekli çalışır halde kalmasını sağlamak için servis kurulumu gerekli.

sudo nano /etc/systemd/system/kestrel-app1.service


[Unit]
Description=dotnet core web app
[Service]
WorkingDirectory=/var/www/siteadi.com
ExecStart=/usr/bin/dotnet /var/www/siteadi.com/WebApp.dll
Restart=always
# Restart service after 10 seconds if the dotnet service crashes:
RestartSec=10
KillSignal=SIGINT
SyslogIdentifier=dotnet-example
User=www-data
Environment=ASPNETCORE_ENVIRONMENT=Production
Environment=DOTNET_PRINT_TELEMETRY_MESSAGE=false
[Install]
WantedBy=multi-user.target


sudo systemctl enable kestrel-app1.service
sudo systemctl start kestrel-app1.service

Ftp ile bağlanıp dosya yükleme de sorun yaşıyorsanız kendinize yetki vererek sorunu çözebilirsiniz.

sudo chown kullaniciadi:root /var/www/siteadi.com/ -Rf