docker 使用 nginx 并配置域名

目录

一、docker 安装nginx

        1、搜索nginx 镜像

        2、拉取nginx镜像

        3、运行镜像

        4、拷贝 nginx容器中的文件到主机目录

        5、停止并删除容器

        6、重启nginx

        7、检测nginx是否启动成功

二、nginx配置转发多个端口

        1、docker启动容器后,在挂载出来的nginx里找到nginx.conf

        2、或者进入容器,用指令修改配置文件

        3、配置文件

        4、配置后重启nginx

        5、登入项目测试内部转发是否成功,注:各个容器都有不同的ip,不能用127.0.0.1

三、配置域名

        1、首先去申请域名,拿到ssl证书,在挂在出来的nginx路径下创建一个cert文件夹,复制进去

        2、将证书复制到容器里

        3、修改配置文件

        4、重启nginx

        5、检测是否配置成功


一、docker 安装nginx

        1、搜索nginx 镜像
docker search nginx
        2、拉取nginx镜像
docker pull nginx:latest
        3、运行镜像
docker run -d --name nginx -p 80:80 -p 443:443 nginx:latest
        4、拷贝 nginx容器中的文件到主机目录
docker cp nginx:/etc/nginx/nginx.conf /usr/local/nginx/
docker cp nginx:/etc/nginx/conf.d /usr/local/nginx/conf/
docker cp nginx:/usr/share/nginx/html /usr/local/nginx/html
docker cp nginx:/var/log/nginx/ /usr/local/nginx/logs/
        5、停止并删除容器
docker stop nginx
docker rm nginx
        6、重启nginx
docker run -d  --name nginx -p 80:80 -p 443:443 -v /usr/local/nginx/nginx.conf:/etc/nginx/nginx.conf -v /usr/local/nginx/logs:/var/log/nginx -v /usr/local/nginx/html:/usr/share/nginx/html -v /usr/local/nginx/conf:/etc/nginx/conf.d  --privileged=true     -e TZ=Asia/Shanghai nginx:latest
        7、检测nginx是否启动成功

可以查看log

docker logs nginx

可以直接访问查看 http://ip,出现这个就是启动成功

二、nginx配置转发多个端口

        1、docker启动容器后,在挂载出来的nginx里找到nginx.conf

        2、或者进入容器,用指令修改配置文件

此时如果报错

如果是基于Debian或Ubuntu的系统,可以使用sudo apt-get install vim

如果是基于Red Hat的系统,可以使用sudo yum install vimsudo dnf install vim

如果是macOS,可以使用brew install vim

编辑完 按esc  输入指令:wq 即可

        3、配置文件


user  nginx;
worker_processes  auto;

error_log  /var/log/nginx/error.log notice;
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;


        location / {
            root   /usr/local/nginx/html;
            index  login.html index.htm;
        }
#         实例一的前端页面,主要root 要换成alias
        location /web1 {
#         多个前端项目,需要使用alias
            alias   /usr/local/nginx/html/web1 ;
            index  login.html index.htm;
        }
#         实例二的前端页面
        location /web2 {
            alias   /usr/local/nginx/html/web2;
            index  login.html index.htm;
        }
#         实例一的后端配置,主要看proxy_pass
         location  /java1/ {

            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;

            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
            proxy_read_timeout 3600s;
                        proxy_pass  http://ip:port1/;
        }
        location  /java2/ {

            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;

            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
            proxy_read_timeout 3600s;
                        proxy_pass  http://ip:port2/;
        }
  }
}

        4、配置后重启nginx
docker restart nginx
        5、登入项目测试内部转发是否成功,注:各个容器都有不同的ip,不能用127.0.0.1

三、配置域名

        1、首先去申请域名,拿到ssl证书,在挂在出来的nginx路径下创建一个cert文件夹,复制进去

        2、将证书复制到容器里
docker cp /usr/local/nginx/cert nginx:/etc/nginx/
        3、修改配置文件


user  nginx;
worker_processes  auto;

error_log  /var/log/nginx/error.log notice;
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 xxx.xxx.com; # 你的域名
        return 301 https://$server_name$request_uri; # 重定向到HTTPS
     }
    server {
        listen 443 ssl;
        server_name  xxx.xxx.com;

        ssl_certificate /etc/nginx/cert/xxx.xxx.com.pem; # SSL证书文件路径
        ssl_certificate_key /etc/nginx/cert/xxx.xxx.com.key; # SSL私钥文件路径
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
        ssl_prefer_server_ciphers on;

        location / {
            root   /usr/share/nginx/html;
            index  index.html index.htm;
        }
       location /web1 {
      alias /usr/share/nginx/html/web1 ;
      index index.html;
    }
    location /web2 {
      alias /usr/share/nginx/html/web2 ;
      index index.html;
    }
    location /java1/ {

            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;

            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
            proxy_read_timeout 3600s;

            proxy_pass http://xxx.xxx.com:port1;
    }
    location /java2/ {

            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;

            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
            proxy_read_timeout 3600s;

            proxy_pass http://xxx.xxx.com:port2;
    }
    location /java3/ {

            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;

            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
            proxy_read_timeout 3600s;

            proxy_pass http://xxx.xxx.com:port3;
    }

   }
}
 

        4、重启nginx
docker restart nginx
        5、检测是否配置成功

在浏览器输入域名或https://xxx.xxx.com/,输入http://ip,使用项目访问,各种项目皆访问成功,即配置成功

参考链接:docker 安装 nginx 发布Vue项目_docker nginx vue-CSDN博客

nginx配置同一个端口转发多个项目_nginx配置多个转发-CSDN博客

 Nginx配置一个域名多端口+HTPPS协议_nginx监听多个端口-CSDN博客

  • 26
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker 使用 Nginx 反向代理的步骤如下: 1. 首先,你需要创建一个 Dockerfile 文件来定义你的 Nginx 容器。在 Dockerfile 中,你可以指定基础镜像、安装 Nginx,以及配置反向代理。 以下是一个简单的示例 Dockerfile: ```Dockerfile FROM nginx # 删除默认的 Nginx 配置文件 RUN rm /etc/nginx/conf.d/default.conf # 添加你的自定义 Nginx 配置文件 COPY nginx.conf /etc/nginx/conf.d/ # 暴露 Nginx 监听的端口号 EXPOSE 80 ``` 2. 创建一个名为 `nginx.conf` 的文件,用来配置 Nginx 的反向代理规则。根据你的需求,你可以根据自己的实际情况进行配置,下面是一个简单的示例: ```nginx server { listen 80; server_name your_domain.com; location / { proxy_pass http://your_upstream_server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } ``` 将 `your_domain.com` 替换为你要将流量转发到的域名,将 `your_upstream_server` 替换为将接收到的请求转发到的上游服务器地址。 3. 构建 Docker 镜像。在终端中导航到 Dockerfile 所在的目录,并运行以下命令构建镜像: ```bash docker build -t your_image_name . ``` 将 `your_image_name` 替换为你想要的镜像名称。 4. 运行 Docker 容器。使用以下命令运行刚刚构建的镜像: ```bash docker run -d -p 80:80 your_image_name ``` 这将在后台运行一个新的容器,并将主机的 80 端口映射到容器的 80 端口。 现在,你的 Nginx 反向代理容器已经启动并运行。你可以通过访问主机的 IP 地址或域名来验证反向代理是否正常工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值