文章目录

  • docker部署nginx 并实现反向代理 配置多个域名多个端口
  • 1. 安装nginx:
  • 2. 以终端的方式打开镜像容器
  • default.conf:
  • nginx.conf:
  • 3. 在linux中创建挂载配置文件和文件夹
  • 反向代理:
  • 4. 创建容器并挂载文件和文件夹
  • 这一步:如果挂载之后容器运行正常却依然不能通过域名访问可尝试以下操作
  • 注意:每一次更改配置文件都需要重启容器
  • 解决nginx将css文件解析为text/plain


docker部署nginx 并实现反向代理 配置多个域名多个端口

1. 安装nginx:

docker pull nginx

2. 以终端的方式打开镜像容器

docker run -i -t docker.io/nginx /bin/bash
这里pull的nginx镜像为docker.io/nginx

(关键)查看nginx镜像里面配置文件、日志等文件的具体位置,
只有找到镜像配置文件的路径,后面挂载文件和文件夹才能覆盖这些路径:

找到镜像中nginx.conf配置文件路径: /etc/nginx/nginx.conf
用命令:
    cat  /etc/nginx/nginx.conf
    查看nginx.conf文件内容然后拷贝出来

找到default.conf配置文件的路径: /etc/nginx/conf.d/default.conf

用命令:
    cat  /etc/nginx/conf.d/default.conf 
    查看default.conf文件内容然后拷贝出来
    
找到默认首页文件夹html路径: /usr/share/nginx/html

找到日志文件路径: /var/log/nginx

然后输入exit退出容器的终端

default.conf:

server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

nginx.conf:

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

3. 在linux中创建挂载配置文件和文件夹

mkdir -p /nginx/conf
mkdir -p /nginx/conf.d
mkdir -p /nginx/html
mkdir -p /nginx/logs
在conf文件夹创建nginx.conf: 并拷贝内容粘贴到文件中,:wq退出保存
    vi nginx.conf

在conf.d文件夹创建default.conf,并拷贝内容粘贴到文件中,:wq退出保存
    vi default.conf

反向代理:

如创建light4d.top.conf, 其他的域名代理相同,只要改server_name和proxy_pass代理端口,配置文件需以.conf结尾,

在这里我配置了www.light4d.top.conf和doc.lightmap.com,分别创建light4d.top.conf,doc.lightmap.conf文件,反向代理端口分别为8002,8052

light4d.top.conf
添加以下配置信息:
    server {
        listen 80;
        server_name www.light4d.top; # 域名
        location / {
            proxy_set_header  Host  $http_host;
            proxy_set_header  X-Real-IP  $remote_addr;
            proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://39.98.226.118:8002; # 代理ip:端口
        }
    }
doc.lightmap.conf
添加以下配置信息:
    server {
        listen 80;
        server_name doc.lightmap.top; # 域名
        location / {
            proxy_set_header  Host  $http_host;
            proxy_set_header  X-Real-IP  $remote_addr;
            proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://39.98.226.118:8052; # 代理ip:端口
        }
    }

4. 创建容器并挂载文件和文件夹

这里所挂载的文件和文件夹路径必须和以上所创建的配置文件路径一致

docker run  --name nginx -d -p 80:80 -v /nginx/html:/usr/share/nginx/html -v /nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /nginx/conf.d:/etc/nginx/conf.d  -v /nginx/logs:/var/log/nginx docker.io/nginx

这一步:如果挂载之后容器运行正常却依然不能通过域名访问可尝试以下操作

向名称为nginx的容器发送脚本命令
    docker exec -it nginx /bin/bash
重新加载配置命令
    cd /etc/nginx/conf.d
    service nginx reload
 检查配置文件路径是否正确

注意:每一次更改配置文件都需要重启容器

docker restart nginx // 重启nginx容器
docker ps  // 查看容器状态
docker logs -t nginx // 如果挂载失败,查看nginx容器log,显示错误信息,根据错误信息 更改配置文件等

以上配置完成之后能够通过域名访问网站,但是css样式却被nginx解析成text/plain,打开控制台可看到warn信息

解决nginx将css文件解析为text/plain

方法一:来自网上的普遍解决办法

ngin.conf中http添加:
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

注:此办法并不能使我网站的css正确解析,因为在拷贝nginx镜像中的原配置文件时,就已经添加mime.types了。却依然不能正确解析。

方法二:解析成功,原因未知

将index.html中<!DOCTYPE html>去掉。

通过域名访问:成功!!

借鉴此博文,感谢。