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守护程序重新启动后也不会重新启动容器。
posted @ 2022-02-07 13:01  顽皮大叔  阅读(1710)  评论(0编辑  收藏  举报