天天看點

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

引言

Docker釋出于2013年,Docker是dotCloud公司創始人在法國期間發起的一個公司内部項目,他是dotCloud多年雲技術的一個革新.Docker在容器基礎上進行了一步的封裝,從網絡程序到網絡互連到程序隔離極大的減少了容器的建立和維護,Docker比虛拟機技術更加便捷.

Docker是個跨時代的開源項目,他釋放了虛拟化的威力,降低了雲計算的開發成本,可以讓線上線下的部署的成本變低,無論是開發人員還是運維等資訊人員都有必要去了解和掌握Docker,減少不必要的時間成本,遠離它(996),當然Docker在如火如荼的時代也成為了面試的加分項.

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

Base

倉庫

倉庫是放鏡像的地方,同時我們可以往裡推鏡像,同一個鏡像也可以有多個版本(tag),也就是标簽

鏡像

鏡像其實是将應用打包運作的環境,他是一個輕量級的(實際開發中可以将鏡像導出并複制到另一台機器.)

拉鏡像

docker pull xxx

搜尋鏡像

docker search xxx

删除鏡像

docker rmi xxid

容器

容器相當于類與執行個體關系,容器是鏡像運作時的實體。容器可以被建立、啟動、停止、删除、暫停等 。

正在運作的指令

docker ps

運作指令

docker run xxx /bin/bash

殺掉運作中的容器

docker kill [CONTAINERID]

Docker Nginx

先拉鏡像吧

docker pull nginx

搜尋一下本地剛才安裝的鏡像

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

鏡像資源有了,那麼我再啟動一個容器執行個體

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)
  • --name是容器名稱
  • -p 是端口進行映射,将本地8010映射到容器内部的80端口
  • -d 設定在背景運作的容器

Run

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

上面運作沒問題了,但是并滿足不了日常需求,下面我示範一下如何在docker nginx運作靜态頁面

建立 conf、 www、logs檔案夾

  • www:映射nginx容器配置虛拟目錄
  • conf:映射nginx配置檔案
  • logs:映射日志檔案目錄

在www目錄下面建立一個index.html

将nginx檔案配置拷貝到本地目錄中

docker cp 2b3869ba5206:/etc/nginx/nginx.conf /docker/conf

部署

docker run -d -p 8011:80 --name blognginx-test-web -v ~/docker/www:/usr/share/nginx/html -v ~/docker/conf/nginx.conf:/etc/nginx/nginx.conf -v ~/docker/logs:/var/log/nginx nginx

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)
  • -p 8011:80:将容器的80端口映射到主機的8011端口。
  • --name blognginx-test-web:将容器命名為 blognginx-test-web。
  • -v ~/nginx/www:/usr/share/nginx/html:将www挂載到/usr/share/nginx/html
  • -v ~/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:将nginx.conf挂載到/etc/nginx/nginx.conf
  • -v ~/nginx/logs:/var/log/nginx:logs挂載到/var/log/nginx

Docker DotNetCore

netcore項目釋出到docker并且通過nginx進行代理

建立一個項目工程,再建立個檔案 Dockerfile

FROM mcr.microsoft.com/dotnet/core/aspnet:3.0-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443

FROM base AS final
WORKDIR /app
COPY . .
ENTRYPOINT ["dotnet", "DockerDeployDemo.dll"]
           
asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

docker build -t dockerwebtest .

建構鏡像

docker run --name dockerwebtest -p 8012:80 dockerwebtest

//運作鏡像

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

code 200

通過nginx進行代理,附上nginx代碼

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    #include /etc/nginx/conf.d/*.conf;
	
	    server {
        listen       80;
        server_name  localhost;
        
        #charset koi8-r;

        #access_log  logs/host.access.log  main;
		#access_log logs/access.log main;
        #error_log logs/error.log;
	 location / {
             
             proxy_pass http://172.17.0.1:8012;
  
             proxy_http_version 1.1;
   
             proxy_set_header Upgrade $http_upgrade;
 
             proxy_set_header Connection keep-alive;
    
             proxy_set_header Host $http_host;
           
             proxy_cache_bypass $http_upgrade;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header REMOTE-HOST $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

         }


    }
	
}

           

修改完後重新啟動8011端口的容器

asp.netcore 3.0 Docker Nginx(震驚,原來docker是這樣的!)

Demo已釋出到github上面有需要的可以進行下載下傳.

概要

Demo:https://github.com/fhcodegit/DotNetAspectCore/tree/master/DockerDeployDemo