Nginx:支持 HTTPS

文章目录

    • [Nginx 开启 ssl 以支持 HTTPS](#Nginx 开启 ssl 以支持 HTTPS)
      • [1 生成本地证书](#1 生成本地证书)
      • [2 开启 ssl 以支持 HTTPS](#2 开启 ssl 以支持 HTTPS)
      • [3 将 https 的请求转发给 http](#3 将 https 的请求转发给 http)
    • [最终的 nginx.conf 如下](#最终的 nginx.conf 如下)

Nginx 开启 ssl 以支持 HTTPS

!IMPORTANT

在下文中,将采用如下定义。

HTTP端口: 80

HTTPS端口: 443

服务地址: www.0ll1.com,也可以是 IP

1 生成本地证书

  1. 生成一个 RSA 私钥:server.key

    nginx 复制代码
    openssl genrsa -out server.key 2048
  2. 生成一个自签名的 X.509 证书:server.crt

    nginx 复制代码
    openssl req -new -x509 -days 8760 -key server.key -out server.crt -subj "/C=CN/O=Institute of Information Engineering, CAS/CN=www.0ll1.com"

2 开启 ssl 以支持 HTTPS

nginx 复制代码
server {
    listen 443 ssl;
    server_name www.0ll1.com;
    ssl_certificate /usr/local/nginx/cert/server.crt;
    ssl_certificate_key /usr/local/nginx/cert/server.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH;
    ssl_prefer_server_ciphers on;
}

3 将 https 的请求转发给 http

nginx 复制代码
server {
    location / {
        proxy_set_header Host $host;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_connect_timeout 60;
        proxy_read_timeout 600;
        proxy_send_timeout 600;
        proxy_pass http://www.0ll1.com:80;
    }
}

!NOTE

只需要将 proxy_pass 修改为 http 服务的 url 即可。

最终的 nginx.conf 如下

nginx 复制代码
server {
    listen 443 ssl;
    server_name www.0ll1.com;
    ssl_certificate /usr/local/nginx/cert/server.crt;
    ssl_certificate_key /usr/local/nginx/cert/server.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH;
    ssl_prefer_server_ciphers on;

    location / {
        proxy_set_header Host $host;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_connect_timeout 60;
        proxy_read_timeout 600;
        proxy_send_timeout 600;
        proxy_pass http://www.0ll1.com:80;
    }
}
相关推荐
xixixi77777几秒前
互联网和数据分析中的核心指标 DAU (日活跃用户数)
大数据·网络·数据库·数据·dau·mau·留存率
范纹杉想快点毕业42 分钟前
状态机设计与嵌入式系统开发完整指南从面向过程到面向对象,从理论到实践的全面解析
linux·服务器·数据库·c++·算法·mongodb·mfc
这周也會开心1 小时前
Redis与MySQL回写中的数据类型存储设计
数据库·redis·mysql
Aaron_Wjf1 小时前
PG Vector测试
数据库·postgresql
Aaron_Wjf1 小时前
PG逻辑复制槽应用
数据库·postgresql
一碗面4211 小时前
SQL性能优化:让数据库飞起来
数据库·sql·性能优化
June bug2 小时前
【高频SQL基础版】排序和分组
数据库·sql
珠海西格2 小时前
光伏电站全景感知体系:数据采集与设备状态监测技术
大数据·运维·服务器·数据库·人工智能
爱基百客2 小时前
从人鼠到植物:SEdb 3.0数据库一站式检索与分析超级增强子调控网络
数据库·国自然·转录因子·组蛋白修饰·增强子
来来走走2 小时前
rocky linux 9.7安装mysql 8.4+
linux·数据库·mysql