docker中nginx添加SSL证书,并支持http和https连接

背景

最近在弄一个小程序,小程序上线需要后端https访问。那我原先的需要在nginx中添加SSL证书

关于SSL证书,可以去阿里云或者腾讯云去申请。不过现在个人免费版只有3个月的有效期。我们申请到证书后,放到nginx中

我们新增了一个cert文件夹

bash 复制代码
mkdir cert

然后将证书的key和pom丢进去

因为我的项目之前在docker里已经用了nginx做代理,所以我这里就不再赘述docker安装nginx的流程。

就直接修改nginx的配置文件,需要在http块内再配置一个server

bash 复制代码
    server {
     #HTTPS的默认访问端口443。
     #如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
     listen 443 ssl;
     
     #填写证书绑定的域名
     server_name www.xxxx.com;
 
     #填写证书文件 容器内的路径,启动容器的时候挂载上就行
     ssl_certificate /etc/nginx/conf/cert/www.xx.com.pem;
     #填写证书私钥文件绝对路径
     ssl_certificate_key /etc/nginx/conf/cert/www.xx.com.key;
 
     ssl_session_cache shared:SSL:1m;
     ssl_session_timeout 5m;
	 
     #自定义设置使用的TLS协议的类型以及加密套件(以下为配置示例,请您自行评估是否需要配置)
     #TLS协议版本越高,HTTPS通信的安全性越高,但是相较于低版本TLS协议,高版本TLS协议对浏览器的兼容性较差。
     ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
     ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;

     #表示优先使用服务端加密套件。默认开启
     ssl_prefer_server_ciphers on;
 
 
    location / {
            alias /img_data/ftp/ftpuser/upload/;
            autoindex on;
            index index.html index.htm;

    }
    location /main/ {
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://xxxxxx:9005/main/; # 反向代理
    }
}

另外我们还做了一个端口转发,把小程序的访问转到了9005端口

然后启动容器

bash 复制代码
docker run  -it --restart=always -p 9001:80 -p 9006:443 --name nginx-hy4 -v /home/nginx/conf/nginxnew.conf:/etc/nginx/nginx.conf -v /home/nginx/conf/conf.d:/etc/nginx/conf.d -v /home/nginx/conf/cert:/etc/nginx/conf/cert -v /img_data/ftp/ftpuser/upload/:/img_data/ftp/ftpuser/upload/  nginx:latest

9001是http的端口,9006是https的端口

相关推荐
妍妍的宝贝11 分钟前
k8s 中微服务之 MetailLB 搭配 ingress-nginx 实现七层负载
nginx·微服务·kubernetes
读心悦20 分钟前
如何在 Axios 中封装事件中心EventEmitter
javascript·http
大道归简43 分钟前
Docker 命令从入门到入门:从 Windows 到容器的完美类比
windows·docker·容器
CXDNW1 小时前
【网络篇】计算机网络——应用层详述(笔记)
服务器·笔记·计算机网络·http·web·cdn·dns
zeruns8021 小时前
如何搭建自己的域名邮箱服务器?Poste.io邮箱服务器搭建教程,Linux+Docker搭建邮件服务器的教程
linux·运维·服务器·docker·网站
爱跑步的程序员~1 小时前
Docker
docker·容器
疯狂的大狗2 小时前
docker进入正在运行的容器,exit后的比较
运维·docker·容器
长天一色2 小时前
【Docker从入门到进阶】01.介绍 & 02.基础使用
运维·docker·容器
伊玛目的门徒2 小时前
docker 搭建minimalist-web-notepad
运维·docker·notepad
秋夫人3 小时前
http cache-control
网络·网络协议·http