Docker容器中.netcore/Nginx配置SSL证书监听443端口

由于小程序域名需要配置https请求,不得不苦心钻研,自己总结了一下。

我是用的.netcore写的webapi,配置的8080端口,要配置https,需要通过nginx监听443端口转发

  • 一、准备文件ssl两个文件

1_www.test.club_bundle.crt

2_www.test.club.key

备注:我是在腾讯云申请的证书,下载解压,里面有nginx文件夹,对应着两个文件

  • 二、新建nginx映射文件夹 
       mkdir /root/nginx/data   
       mkdir /root/nginx/config
       mkdir /root/nginx/config/conf.d
       mkdir /root/nginx/logs
       mkdir /root/nginx/ssl

 

备注:data存储html文件,config存储配置文件,conf.d存储配置文件,logs存储日志,ssl存储一中两个ssl文件。

  • 三、准备配置文件

把一中准备的两个文件夹拷贝到文件夹/root/nginx/ssl中

新建nginx.conf文件,拷贝到/root/nginx/config文件夹,nginx.conf内容如下

#运行nginx的用户
user  nginx;
#启动进程设置成和CPU数量相等
worker_processes  1;

#全局错误日志及PID文件的位置
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;

#工作模式及连接数上限
events {
        #单个后台work进程最大并发数设置为1024
    worker_connections  1024;
}


http {
        #设定mime类型
    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压缩
    #gzip  on;

    include /etc/nginx/conf.d/*.conf;

}

 

新建default.conf文件,并拷贝到/root/nginx/config/conf.d文件夹下,内容如下

server {
    #侦听80端口,如果强制所有的访问都必须是HTTPs的,这行需要注销掉
    #listen    80;       
    listen    443 ssl;
    server_name test.club www.test.club;             #域名

    # 增加ssl
    #ssl on;        #如果强制HTTPs访问,这行要打开
    ssl_certificate /ssl/1_www.test.club_bundle.crt;
    ssl_certificate_key /ssl/2_www.test.club.key;

    ssl_session_cache    shared:SSL:1m;
    ssl_session_timeout  5m;

     # 指定密码为openssl支持的格式
     ssl_protocols  SSLv2 SSLv3 TLSv1.2;

     ssl_ciphers  HIGH:!aNULL:!MD5;  # 密码加密方式
     ssl_prefer_server_ciphers  on;   # 依赖SSLv3和TLSv1协议的服务器密码将优先于客户端密码

     # 定义首页索引目录和名称
     location / {
        proxy_pass http://外网IP:8080;
     }

    #重定向错误页面到 /50x.html
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
}

 

四、拉取最新的nginx镜像,并运行

拉取最新镜像

docker pull nginx:latest

启动nginx容器

docker run --detach \
        --name mynginx \
        -p 443:443\
        -p 80:80 \
        -v /root/nginx/data:/usr/share/nginx/html:rw\
        -v /root/nginx/config/nginx.conf:/etc/nginx/nginx.conf:rw\
        -v /root/nginx/config/conf.d:/etc/nginx/conf.d:rw\
        -v /root/nginx/logs:/var/log/nginx:rw\
        -v /root/nginx/ssl:/ssl:rw\
        -d nginx

然后访问https://www.test.club/swagger/index.html就映射到了8080端口

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值