Linux部署SSL证书教程

在 Linux 上部署 SSL 证书通常涉及以下步骤,具体操作可能因 Web 服务器(如 Nginx、Apache)而异。以下是通用流程:


1. 准备 SSL 证书文件

从证书颁发机构(CA)获取证书后,通常会得到以下文件:

  • 证书文件 (如 yourdomain.crtyourdomain.pem
  • 私钥文件 (如 yourdomain.key
  • 中间证书链文件 (如 ca_bundle.crt,可选,部分 CA 会提供)

将文件上传到服务器的安全目录(如 /etc/ssl/):

bash 复制代码
sudo mkdir -p /etc/ssl/yourdomain
sudo cp yourdomain.crt /etc/ssl/yourdomain/
sudo cp yourdomain.key /etc/ssl/yourdomain/
sudo cp ca_bundle.crt /etc/ssl/yourdomain/  # 如果有

2. 配置 Web 服务器

Nginx 配置示例

编辑站点配置文件(如 /etc/nginx/sites-available/yourdomain.conf):

nginx 复制代码
server {
    listen 443 ssl;
    server_name yourdomain.com www.yourdomain.com;

    ssl_certificate /etc/ssl/yourdomain/yourdomain.crt;
    ssl_certificate_key /etc/ssl/yourdomain/yourdomain.key;
    
    # 如果存在中间证书链,合并到证书文件或单独指定
    # ssl_trusted_certificate /etc/ssl/yourdomain/ca_bundle.crt;

    # 其他 SSL 优化配置
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_prefer_server_ciphers on;
    ssl_ciphers "ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256";

    # 其他站点配置...
}

# 强制 HTTP 跳转到 HTTPS
server {
    listen 80;
    server_name yourdomain.com www.yourdomain.com;
    return 301 https://$host$request_uri;
}

测试配置并重启 Nginx:

bash 复制代码
sudo nginx -t   # 测试配置
sudo systemctl restart nginx

Apache 配置示例

编辑虚拟主机文件(如 /etc/apache2/sites-available/yourdomain.conf):

apache 复制代码
<VirtualHost *:443>
    ServerName yourdomain.com
    ServerAlias www.yourdomain.com

    SSLEngine on
    SSLCertificateFile /etc/ssl/yourdomain/yourdomain.crt
    SSLCertificateKeyFile /etc/ssl/yourdomain/yourdomain.key
    SSLCertificateChainFile /etc/ssl/yourdomain/ca_bundle.crt  # 如果有

    # 其他配置...
</VirtualHost>

# 强制 HTTP 跳转
<VirtualHost *:80>
    ServerName yourdomain.com
    Redirect permanent / https://yourdomain.com/
</VirtualHost>

启用模块并重启 Apache:

bash 复制代码
sudo a2enmod ssl
sudo a2ensite yourdomain.conf
sudo systemctl restart apache2

3. 验证 SSL 配置

  • 浏览器访问 :通过 https://yourdomain.com 检查证书是否生效。

  • 命令行工具

    bash 复制代码
    curl -vI https://yourdomain.com
    openssl s_client -connect yourdomain.com:443 -servername yourdomain.com
  • 在线工具 :使用 SSL Labs 检测配置安全性。


常见问题

  1. 权限问题 :确保私钥文件(.key)仅对 root 可读:

    bash 复制代码
    sudo chmod 600 /etc/ssl/yourdomain/yourdomain.key
  2. 证书链不完整 :合并证书和中间链:

    bash 复制代码
    cat yourdomain.crt ca_bundle.crt > combined.crt
  3. 防火墙 :确保 443 端口开放:

    bash 复制代码
    sudo ufw allow 443/tcp

根据实际环境调整路径和配置。如果是云服务器(如 AWS、阿里云),部分平台提供证书托管服务,可直接绑定到负载均衡器或 CDN。

相关推荐
大象席地抽烟9 分钟前
Spring AI RAG 体验项目
后端
SimonKing21 分钟前
百度统计、Google Analytics平替开源网站分析工具:Umami
java·后端·程序员
欲买桂花同载酒44 分钟前
postgis空间坐标系实践
后端
码事漫谈1 小时前
智能运维与资源优化:金仓数据库助力企业年省百万运维成本
后端
苏三说技术1 小时前
5种分布式配置中心
后端
武子康1 小时前
大数据-148 Flink 写入 Kudu 实战:自定义 Sink 全流程(Flink 1.11/Kudu 1.17/Java 11)
大数据·后端·nosql
星释1 小时前
Rust 练习册 :Macros与宏系统
开发语言·后端·rust
林太白2 小时前
rust18-通知管理模块
后端·rust
一 乐2 小时前
医疗管理|医院医疗管理系统|基于springboot+vue医疗管理系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·医疗管理系统