当前位置: 首页 > article >正文

【Nginx】Nginx 使用 SSL 的详细指南

目录

  • 1. 引言
  • 2. 准备工作
    • 2.1 安装 Nginx
      • 在 Ubuntu 上安装 Nginx
      • 在 CentOS 上安装 Nginx
    • 2.2 获取 SSL 证书
      • 使用 Let’s Encrypt 获取证书
  • 3. 配置 Nginx 启用 SSL
    • 3.1 编辑 Nginx 配置文件
    • 3.2 添加 SSL 配置
  • 4. 强化 SSL 配置
    • 4.1 选择安全的加密套件
    • 4.2 启用 HSTS
  • 5. 测试 SSL 配置
  • 6. 续订和更新 SSL 证书
  • 结论
  • 参考资料

1. 引言

在当今的网络环境中,数据安全至关重要。SSL(安全套接字层)和 TLS(传输层安全协议)为数据传输提供了加密保护。Nginx 是一款高性能的 Web 服务器,广泛应用于处理 HTTPS 请求。本文将详细介绍如何在 Nginx 中配置 SSL。

2. 准备工作

2.1 安装 Nginx

首先,确保 Nginx 已安装在你的服务器上。可以通过以下命令进行安装:

在 Ubuntu 上安装 Nginx

sudo apt update
sudo apt install nginx

在 CentOS 上安装 Nginx

sudo yum install epel-release
sudo yum install nginx

安装完成后,通过以下命令验证 Nginx 是否正常运行:

sudo systemctl start nginx
sudo systemctl enable nginx

2.2 获取 SSL 证书

你可以选择购买商业 SSL 证书,或者使用 Let’s Encrypt 提供的免费 SSL 证书。

使用 Let’s Encrypt 获取证书

  1. 安装 Certbot(用于自动化证书获取和续订):

    sudo apt install certbot python3-certbot-nginx
    
  2. 获取证书

    sudo certbot --nginx -d yourdomain.com -d www.yourdomain.com
    

根据提示完成配置,Certbot 会自动为你配置 Nginx。

3. 配置 Nginx 启用 SSL

3.1 编辑 Nginx 配置文件

找到并打开你的 Nginx 配置文件,通常位于 /etc/nginx/sites-available/default/etc/nginx/nginx.conf

3.2 添加 SSL 配置

在 server 块中添加以下内容:

server {
    listen 443 ssl;
    server_name yourdomain.com www.yourdomain.com;

    ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;

    location / {
        proxy_pass http://localhost:3000;  # 根据需要调整
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

4. 强化 SSL 配置

4.1 选择安全的加密套件

为了提高安全性,你可以选择推荐的加密套件:

ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384';
ssl_prefer_server_ciphers on;

4.2 启用 HSTS

HTTP Strict Transport Security(HSTS)可以防止中间人攻击:

add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;

5. 测试 SSL 配置

在重启 Nginx 之前,先测试配置是否有效:

sudo nginx -t

如果一切正常,重启 Nginx 使更改生效:

sudo systemctl restart nginx

你可以使用 SSL Labs 在线工具来检查 SSL 配置的安全性。

6. 续订和更新 SSL 证书

Let’s Encrypt 的证书有效期为 90 天,建议设置自动续订。Certbot 默认会自动设置 cron 任务进行续订,但你可以手动测试续订:

sudo certbot renew --dry-run

结论

通过以上步骤,你可以在 Nginx 中成功配置 SSL,提高网站的安全性。定期检查和更新你的 SSL 配置,以确保最佳的安全性。

参考资料

  • Nginx 官方文档
  • SSL/TLS 最佳实践指南

希望这个详细的博客内容能够帮助你成功配置 Nginx SSL!如果需要进一步的细节或有其他问题,随时问我!


http://www.kler.cn/news/316233.html

相关文章:

  • 内核是如何发送数据包
  • Python国产新 ORM 框架 fastzdp_sqlmodel 快速入门教程
  • AI时代保持并提升自身的核心竞争力
  • 常⻅中间件漏洞(WebLogic)靶场
  • 树莓派pico上手
  • 构建高可用和高防御力的云服务架构第五部分:PolarDB(5/5)
  • 今日leetCode 反转字符串
  • 第二证券:股价为什么出现大跌?股价大跌时怎么办?
  • 网安开发:杭州某科技银行面经和答案
  • 轻松获取京东商品信息:商品详情API接口使用教程
  • 关系数据库和非关系数据库
  • 信息安全数学基础(15)欧拉定理
  • 8--SpringBoot原理分析、注解-详解(面试高频提问点)
  • 【Python机器学习】NLP信息提取——值得提取的信息
  • Fyne ( go跨平台GUI )中文文档- 扩展Fyne (七)
  • 是什么推动了今年CSP-J/S报名人数的再创新高?
  • 【AI创作组】Matlab绘图基础之plot函数
  • [Redis][String][上]详细讲解
  • 使用Flink命令行和Java API远程提交Flink任务到Yarn
  • DOM XMLHttpRequest
  • yolov5/8/9/10模型在VOC数据集上的应用【代码+数据集+python环境+GUI系统】
  • 如何切换npm到淘宝的最新镜像源?
  • AIoT应用开发:给机器人接入‘记忆‘,完美解决「和谁对话多轮对话」!附 SQLite 入门实战
  • 数据库DML语句详解与实践
  • 金融行业中如何利用数据中台的数据来有效的驱动业务决策呢?
  • [Redis][预备知识]详细讲解
  • Hive企业级调优[1]——计算资源配置
  • 照片写真记录摄影作品记录网站源码
  • setup.py详解 及 pip install用法
  • 【QT开发-Pyside】使用Pycharm与conda配置Pyside环境并新建工程