使用Nginx实现服务器中多容器共存

服务器
有一台腾讯的Linux云主机,在服务器上部署了一个docker(称为ServiceDocker,名称为sign,下同),ServiceDocker内部使用了80、443、3306端口,分别映射到宿主机(云主机)的相同端口(即80、443、3306)。

背景

有一台腾讯的Linux云主机,在服务器上部署了一个docker(称为ServiceDocker,名称为sign,下同),ServiceDocker内部使用了80、443、3306端口,分别映射到宿主机(云主机)的相同端口(即80、443、3306)。

ServiceDocker中安装了XAMPP,在此基础上部署了扫码签到小程序的服务器。ServiceDocker的80和443端口分别提供http和https服务,3306为MySQL数据库的端口。

ServiceDocker绑定了域名sign.famend.cn。

目标

云主机中的一个ServiceDocker占用了80、443端口,如果想在主机中再部署一台服务器对外服务,就不能使用80和443端口了。

我们的目标是在主机中可以部署多个ServiceDocker,每个ServiceDocker绑定各自的域名,对外提供服务,保证80和443端口可用。

[[245398]]

思路

修改ServiceDocker的端口映射,把ServiceDocker端口80、443分别映射到主机的89、449端口,这样主机的80、443端口释放出来了。

释放出来的80和443端口供Nginx使用。安装带Nginx的docker(称为NginxDocker,名称为mynginx,下同)。NginxDocker内部使用端口80、443,分别映射到主机的80和443端口。

NginxDocker用来做反向代理。当有访问请求时,读取Nginx配置后,不同的URL定向到各自对应的Docker。例如:访问http://sign.famend.cn:80,则自动映射到http://sign.famend.cn:89。

实现步骤

1. 修改ServiceDocker的端口映射,释放80和443端口。

Docker没有提供命令修改端口,从网上我找到了2种方法。

方法1:先停止容器,再将容器打包成镜像,接着运行新的镜像。在运行新的镜像时指定新的端口。使用的命令如下:

  1. #先停止容器 
  2. docker stop containerA 
  3. #将容器commit成为一个镜像 
  4. docker commit containerA newImageB 
  5. #运行容器 
  6. docker run -p 8080:8080 -p 8081:8081 -v /home/data/:/home/data/ -dt newImageB 

方法2:先停止容器,接着停止容器服务,然后修改容器配置文件,***启动容器服务、启动容器。步骤如下:

① 停止ServiceDocker(ServiceDocker的名称为sign),停止docker服务。

  1. sudo docker stop sign 
  2. sudo service docker stop 

② 使用 docker ps -a 命令找到要修改容器的 CONTAINER ID。

③ 运行 docker inspect 【CONTAINER ID】 | grep Id 命令。

④ 执行 cd /var/lib/docker/containers 命令令进入找到与 Id 相同的目录。

在执行cd 命令时如果提示permission denied,可以先执行 sudo -s。

进入id对应的目录后,打开文件hostconfig.json。

找到80端口的映射,如下:

  1. "80/tcp": [ 
  2. "HostIp""0.0.0.0"
  3. "HostPort""80" 
  4. }] 
  5.   
  6. 把 "HostPort""80" 修改成 "HostPort""89" , 如下 
  7. "80/tcp": [ 
  8. "HostIp""0.0.0.0"
  9. "HostPort""89" 
  10. }] 

修改之前,ServiceDocker内部的80端口映射为主机的80端口;修改之后,ServiceDocker内部的80端口映射为主机的89端口。

稍加说明,有文章(参考资料中的2、3)提到还需要修改config.v2.json,亲测不需要。这个文件在启动ServiceDocker时会自动修改。

⑤ 启动docker服务,然后启动ServiceDocker(名称为sign)。

  1. sudo service docker start 
  2. sudo docker start sign 

方法(1)和方法(2)都可以,我选用了方法(2)。

在执行完方法(2)之后,打开浏览器验证,提示“网站无法访问”。

初步估计docker中的服务器没有启动,运行命令:

  1. sudo /opt/lampp/lampp stop 
  2. sudo /opt/lampp/lampp start 

运行stop的时候,发现apache 没有启动,可能是修改了80端口的缘故。

在执行start之后,打开浏览器验证http://sign.famend.cn:89和https://sign.famend.cn:449,成功访问。

修改Docker端口的方法并不复杂,如果docker以后的版本能够提供相应命令,相信会方便很多。

顺便,运行 crontab -l 查看ServiceDocker中的定时任务是否启动,如果没启动,运行 service cron start 启动定时任务。

下一步,配置NginxDocker反向代理,让http://sign.famend.cn:80和https://sign.famend.cn:443也能成功访问。

2. 配置NginxDocker反向代理。

① 下载nginx,并运行它。

  1. docker container run \ 
  2.   -d \ 
  3.   -p 80:80 \ 
  4.   -p 443:443 \ 
  5.   --rm \ 
  6.   --name mynginx \ 
  7.   nginx 

② 配置nginx的配置文件。

  1. mkdir nginx-files 
  2. docker container cp mynginx:/etc/nginx . 
  3. mv nginx conf 
  4. vi conf/nginx.conf 

在nginx.conf中,添加如下反向代理信息。

  1. server{ 
  2.   listen          443 ssl; 
  3.   server_name     sign.famend.cn; 
  4.   ssl_certificate  /etc/nginx/ssl/sign.famend.cn/1_sign.famend.cn_bundle.crt; 
  5.   ssl_certificate_key  /etc/nginx/ssl/sign.famend.cn/2_sign.famend.cn.key
  6.  
  7.   location / { 
  8.     proxy_set_header HOST $host; 
  9.     proxy_set_header X-Real-IP $remote_addr; 
  10.     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  11.     proxy_set_header X-Forwarded-Proto $scheme; 
  12.     proxy_pass http://sign.famend.cn:89/; 
  13.   } 
  14.  
  15. server{ 
  16.   listen         80; 
  17.   server_name     famend.cn sign.famend.cn; 
  18.   location / { 
  19.     proxy_set_header HOST $host; 
  20.     proxy_set_header X-Real-IP $remote_addr:89; 
  21.     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  22.     proxy_set_header X-Forwarded-Proto $scheme; 
  23.     proxy_pass http://sign.famend.cn:89/; 
  24.   } 

对于443端口,需要使用ssl_certificate和ssl_certificate_key。在ServiceDocker中证书使用的LetsEncrypt的SSL证书,每90天更新一次。

SSL证书的来源:一种方法,可以让它们共享LetsEncrypt的SSL证书。除此之外,在腾讯注册的域名,腾讯免费提供SSL证书,有效期为1年。

为了简便,我直接使用了腾讯的SSL证书,当然,一年之内,必须在过期之前更新证书。

③ 停止mynginx,然后重启它。

  1. docker container run \ 
  2.   --name mynginx \ 
  3.   --volume "$PWD/conf":/etc/nginx \ 
  4.   -p 80:80 \ 
  5.   -p 443:443 \ 
  6.   -d \ 
  7.   nginx 

这次,去掉 --rm 参数,以便停止运行的时候保留容器。

至此,配置完成。

验证

浏览器中分别打开

  1. sign.famend.cn:80 
  2. sign.famend.cn:89 
  3. sign.famend.cn:449 
  4. sign.famend.cn:443 

都能正常访问。当然,打开449和443时候,可以发现两个URL使用的证书不一样。449是LetsEncrypt提供的,有效期90天;443来自腾讯(颁发机构TrustAsia),有效期1年。

当然,ServiceDocker中的另外一个网站famend.cn,也可以访问:

  1. famend.cn:80 
  2. famend.cn:89 

成功。

责任编辑:武晓燕 来源: 码农的人生
相关推荐

2021-08-05 17:40:05

XpanesLinux服务器

2020-07-23 08:10:54

Nginx服务器流媒体

2019-07-30 10:18:06

NginxKeepalived

2019-09-26 09:04:22

NginxKeepalived服务器

2017-03-06 09:26:56

Nginx服务器 SSL

2019-12-24 14:42:51

Nginx服务器架构

2019-09-10 15:22:17

Nginx服务器架构

2020-05-12 21:17:18

Nginx服务器架构

2019-01-10 11:12:15

Nginx服务器架构

2019-07-21 19:40:25

服务器开发 架构

2019-07-09 14:57:09

代理服务器NginxHTTPS

2009-01-10 18:53:01

服务器ServerDNS

2021-09-10 10:07:17

Nginx虚拟主机服务器

2010-08-19 16:23:44

2018-03-14 11:13:35

Web服务器Nginx

2019-01-28 11:03:03

NginxFastDFS服务器

2010-02-06 10:24:52

CentOS Ngin

2018-02-24 10:15:36

无服务器容器云计算

2021-01-29 14:41:43

Nginx直播服务器rtmp

2018-02-08 08:52:37

点赞
收藏

51CTO技术栈公众号