使用 nginx 容器部署前端项目并实现负载

时间:2023-02-14 18:05:48

运行nginx镜像

1.拉取镜像

docker pull nginx

2.运行

docker run -it --name mynginx -p 8080:80 -d nginx
  • -t: 在新容器内指定一个伪终端或终端。

  • -i: 允许你对容器内的标准输入 (STDIN) 进行交互

  • -p:端口映射分别对应宿主主机(8080)与容器内(80)

  • --name: 后面跟容器名称

  • -d: 设置容器在在后台一直运行

  • --net=host 命令 。Docker 中的 host 模式指定是容器与主机享受相同的 network namespace,在这种情况下,我们访问主机端口就能访问我们的容器。比如说我们运行 tomcat 容器并且用 -- network=host 来指定我们的网络模式为 host,这样我们访问本机的 8080 端口就能访问到我们的 tomcat 容器。 3.验证

http://localhost:8080/

使用 nginx 容器部署前端项目并实现负载

出现如这个页面表示容器运行成功了。接下来就要更改容器中 nginx 的配置了。

配置 nginx

nginx 的默认路径

(1) Nginx配置路径:/etc/nginx/
(2) PID目录:/var/run/nginx.pid
(3) 错误日志:/var/log/nginx/error.log
(4) 访问日志:/var/log/nginx/access.log
(5) 默认站点目录:/usr/share/nginx/html

对nginx进行配置有两种方式,一是使用 docker exec 命令进入nginx容器的可交互式终端里,找到对应的nginx配置文件进行修改,由于我们运行的容器是一个最简操作系统,很多工具都需要额外安装,所以不推荐这种方式。 第二种方式就是进行目录挂载,将容器中nginx配置文件存在的地址映射到我们的宿主主机上。这样只需要把修改后的配置文件,放入对应的目录中即可完成配置,还能将日志输出到宿主主机上,方便我们维护。

下面我们在ubuntu虚拟机上进行目录挂载。

1.创建需要挂载的目录

mkdir -p /usr/local/niu/mynginx/{conf,conf.d,html,log}

2 启动挂载后的容器

docker -v 命令可用于目录挂载。

docker run --name nginx-app -d -p 8089:80 \
-v /usr/local/niu/mynginx/conf/nginx.conf:/etc/nginx/nginx.conf:ro \
-v /usr/local/niu/mynginx/log:/var/log/nginx \
-v /usr/local/niu/mynginx/html:/usr/share/nginx/html \
-v /usr/local/niu/mynginx/conf.d:/etc/nginx/conf.d \
nginx

第一个-v:挂载 nginx 的主配置文件,以方便在宿主机上直接修改容器的配置文件

第二个-v:挂载容器内 nginx 的日志,容器运行起来之后,可以直接在宿主机的这个目录中查看 nginx 日志

第三个-v:挂载静态页面目录

这里直接启动有个问题,报错如下,意思是:不能将一个文件夹挂载到一个文件上。(nginx.conf 的锅)

......: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type.

试一下不挂载 nginx.conf 文件,能够挂载成功

docker run --name nginx-6601 -d -p 8900:6601\
  -v /usr/mynginx/log:/var/log/nginx\
  -v /usr/mynginx/html:/usr/share/nginx/html\
  -v /usr/mynginx/conf.d:/etc/nginx/conf.d\
  nginx

这一块有个很大的坑,docker 是不推荐直接挂载文件的,使用-v 命令,会首先会查询宿主主机上查看有没有你设置的目录,如果没有的话会自动创建一个,所以我们没必要在宿主主机上去创建挂载目录了。直接执行第二步,然后会报错,在宿主主机上找到 mynginx 文件夹删掉里边的nginx.conf文件夹,把你的nginx.conf文件放进去,删掉当前运行的容器,重新按第二步的命令进行启动。容器启动成功,挂载成功。

这个时候我们就可以直接对宿主主机进行操作了,更改完配置文件后,记得 restart 一下容器。

3配置 nginx 实现负载

nginx.conf配置文件

events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;
    keepalive_timeout  65;
    client_max_body_size 200m;

#start
    server{
        listen 6501;
        server_name 39.97.184.218;

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

    server{
        listen 6502;
        server_name 39.97.184.218;

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

    upstream fn {
        server localhost:6501;
        server localhost:6502;
	}

    server {
        listen        80;
        server_name  localhost;
        location / {
            proxy_pass   http://fn;
            index  index.html index.htm;
        }
    }
#end
}

可以看到配置文件中出现了几个端口号。

80 是nginx服务的端口 localhost:80/ => http://fn

6501,6502 监听了我们的两个前端项目。

upstream fn 就是配置的负载了。它的作用就是将请求分发到两个服务中,这里分发的方式是轮询,其他的分发方式可参考大佬们的教程。

当我们刷新页面时会分别访问到我们的两个服务。 效果如下图:

使用 nginx 容器部署前端项目并实现负载

使用 nginx 容器部署前端项目并实现负载

nginx 应用的拓展

添加静态文件夹服务

  location /upload/ {
            alias /usr/share/nginx/html/images/;
            autoindex on; //显示索引
            autoindex_exact_size on; //显示大小
            autoindex_localtime on;   //显示时间
        }

http://localhost:8089/upload/1.png

docker --net=host 命令

启动第 coral-isc 节点

coral-isc-web服务

nginx.conf

	server {
		listen 8090;
		server_name  39.97.184.218;
		location  /  {
			root  /usr/local/niu/coral-isc-web/web;
			index  index.html;
		}
	}

容器命令:

docker run -it -d  --name coral-isc-web 
-v /usr/local/niu/coral-isc-web/nginx.conf:/etc/nginx/nginx.conf 
-v /usr/local/niu/coral-isc-web/web:/usr/local/niu/coral-isc-web/web 
--privileged --net=host nginx

访问:http://localhost:8090/

coral-isc-server

nginx.conf

	server {
		listen 8091;
		server_name  39.97.184.218;
		location  /  {
			root  /usr/local/niu/coral-isc-server/server;
			index  index.html;
		}
	}

容器命令:

docker run -it -d  --name coral-isc-server 
-v /usr/local/niu/coral-isc-server/nginx.conf:/etc/nginx/nginx.conf 
-v /usr/local/niu/coral-isc-server/server:/usr/local/niu/coral-isc-server/server 
--privileged --net=host nginx