Docker部署nginx(进阶)

Keywords: docker, nginx, 反向代理, ssl证书

前言: 本篇记录自己为nginx配置ssl证书,以及开启其反向代理服务。

若还未部署nginx,可以参考我写的上一篇Docker部署nginx(基础)

Docker部署nginx(进阶)

申请阿里云免费DV证书并下载

参考阿里云帮助文档:

上传证书到服务器

假设:

  • SSl证书上传至/home目录
  • 压缩包名为4389002_www.domain.com_nginx.zip
  • 正在运行的容器名为nginx
# 若没有zip和unzip软件,执行以下指令
yum install -y zip unzip

# 解压
unzip 4389002_www.domain.com_nginx.zip

# 将会得到4389002_www.domain.com_nginx.pem 
# 和 4389002_www.domain.com_nginx.key,
# 其中pem使公钥,key使密钥

# 将zip文件移走,然后该目录仅保留pem和key文件
mv 4389002_www.domain.com_nginx.zip ../

进入nginx容器

# 进入nginx容器
# i表示交互,t表示开启终端,bash表示操作终端指令的shell
docker exec -it nginx bash

# 进入/etc/nginx,创建cert目录然后退出
cd /etc/nginx
mkdir cert
exit

将SSl证书复制进容器

# 当前目录仅有key和pem文件
docker cp * nginx:/etc/nginx/cert

配置本地挂载nginx配置文件

  • 进入nginx-data/conf.d目录
  • 新增一个ssl.conf文件,并新增如下内容
server {
    listen 443 ssl;
    server_name www.domain.com;
    ssl_certificate /etc/nginx/cert/4389002_www.domain.com.pem;
    ssl_certificate_key /etc/nginx/cert/4389002_www.domain.com.key;
    ssl_session_timeout 2m;
    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;
    }

}

注意: server_name对应的域名必须和证书保持一致,因为此证书是免费DV证书,仅支持一个证书对应一个单域名。

检查配置并重写加载:

# 检查配置文件
docker exec nginx /etc/init.d/nginx configtest
 
# 重写加载配置文件
docker exec nginx /etc/init.d/nginx reload

测试

测试前检查

  • 检查容器是否暴露443端口

  • 检查防火墙和安全组是否放行443端口

测试网站

  • 在服务器上可以执行指令curl https://localhost
  • 在个人电脑浏览器上输入https://www.domain.com访问网站内容

开启反向代理服务

假设:

  • 6666端口运行主网站服务
  • 6667端口运行博客服务
  • 6668端口运行提供API的后台应用服务
  • 仅开启80端口的代理服务(其它类比即可)

须知

nginx是基于http协议实现的一个软件,其功能是符合http协议标准的,nginx实现反向代理是通过host(主机名)或URI(资源定位符)实现的。因此,nginx实现反向代理一般有以下几种情况:

  1. 将server_name对应的域名与对应的服务建立映射(类比修改host)。
  2. 将localtion对应的资源定位符与对应的服务建立映射(类比修改URI)。
  3. 二者混合使用。

新增配置文件

conf/conf.d目录下新增proxy.conf文件

示例

# 1.仅修改server_name字段
server
{
    listen 80;
    server_name www.domain.com;
    location / {
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://138.159.246.111:6666;
    }

}


# 2.仅修改localtion字段
server
{
    listen 80;
    server_name www.domain.com;
    location /blog {
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://138.159.246.111:6667;
    }

}

# 3.混合使用
server
{
    listen 80;
    server_name help.domain.com;
    location /docs/api {
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://138.159.246.111:6668;
    }

}

注意:上面仅参考示例,必要时可能需要新增字段,例如443端口可能还需要配置ssl证书,部分API可能要限制Method等。


转载申明

本文转载自智小约Docker部署nginx(基础),若转载请注明来源,侵删。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352