Docker 運行Nginx,使用不同的域名綁定轉發到不同的 docker 容器端口,並設置跟隨docker容器自啟動


拉取官方的Nginx鏡像

啟動一個容器

docker run -d -p 80:80 --name mynginx
-v /home/nginx/www:/usr/share/nginx/html
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
-v /home/nginx/conf/conf.d:/etc/nginx/conf.d
-v /home/nginx/logs:/var/log/nginx --privileged=true nginx

nginx

命令說明:
-p 80:80: 將容器的 80 端口映射到主機的 80 端口.
--name mynginx:將容器命名為 mynginx
-v /home/nginx/www:/usr/share/nginx/html:將我們自己創建的 www 目錄掛載到容器的 /usr/share/nginx/html。
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:將我們自己創建的 nginx.conf 掛載到容器的
/etc/nginx/nginx.conf。
-v /home/nginx/conf/conf.d:/etc/nginx/conf.d 將 conf.d目錄下的 *.conf 所有文件都掛載到容器
-v /home/nginx/logs:/var/log/nginx:將我們自己創建的 logs 掛載到容器的 /var/log/nginx。
--privileged=true :使用該參數,container內的root擁有真正的root權限。

nginx.conf 文件詳情

user  root;
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;
}

conf.d 文件夾中增加配置文件

server {
		listen       80;
		server_name  api.xxx.com;
		location / {
				add_header 'Access-Control-Allow-Methods' 'GET,OPTIONS,PUT,DELETE' always;
				add_header 'Access-Control-Allow-Credentials' 'true' always;
				add_header 'Access-Control-Allow-Origin' '$http_origin' always;
				 add_header 'Access-Control-Allow-Headers' 'Authorization,DNT,User-Agent,Keep-Alive,Content-Type,accept,origin,X-Requested-With' always;
				if ($request_method = OPTIONS ) {
					  return 200;
				}
				proxy_pass  http://10.28.111.108:5100;
				proxy_set_header Host $host;
				proxy_set_header X-Real-IP $remote_addr;
		}
	}
如有多個域名則再conf.d文件夾中增加多個配置文件

注意: proxy_pass 配置項一定要寫宿主機的內網IP,這樣才能從 nginx docker 容器 代理到 另一個 docker 容器的訪問路徑,修改配置文件后重啟該nginx容器即可生效

開啟容器的自動啟動

systemctl enable docker.service

開啟容器的自動啟動

docker update --restart=always 44341b8f30aa

使用重啟策略

要為容器配置重新啟動策略,請--restart在使用該docker run命令時使用該標志。--restart標志的值可以是以下任何一種:

  • no 不要自動重啟容器。(默認)
  • on-failure 如果容器由於錯誤而退出,則重新啟動容器,該錯誤表現為非零退出代碼。
  • always 如果容器停止,請務必重啟容器。如果手動停止,則僅在Docker守護程序重新啟動或手動重新啟動容器本身時才重新啟動。(參見重啟政策詳情中列出的第二個項目)
  • unless-stopped 類似於always,除了當容器停止(手動或其他方式)時,即使在Docker守護程序重新啟動后也不會重新啟動容器。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM