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。

相关推荐
一只叫煤球的猫3 分钟前
Java实战:一个类让Java也用上JS的async/await
java·后端·性能优化
程序猿毕设源码分享网40 分钟前
springboot医院信管系统源码和论文
java·spring boot·后端
桦说编程2 小时前
数据丢失,而且不抛出并发异常,多线程使用HashMap踩坑
java·数据结构·后端
颜如玉2 小时前
Redis主从同步浅析
后端·开源·源码
David爱编程4 小时前
对象锁 vs 类锁:Java 并发中的隐形对决
java·后端
努力的小雨5 小时前
我一个写Java的,怎么就开始玩K8s和Jenkins了?!
后端·云原生
winrisef5 小时前
Node.js版本管理工具 || 全配置安装
后端·node.js·nvm·asdf·fnm
池易5 小时前
调用后端接口像调用函数一样简单——Fun改变了我的开发方式
后端·go
Shawn_Shawn5 小时前
Spring-Ai-Mcp-Server 快速入门
后端·agent·mcp
心月狐的流火号5 小时前
分布式事务XA模式:基于数据库的2PC
分布式·后端