Nginx服务器安装SSL证书
您可以通过将SSL证书安装到 Nginx 服务器,使 Nginx 服务器支持 HTTPS
安全访问。本文介绍如何在 Nginx 服务器安装SSL证书。
说明
本文档Nginx版本以 nginx/1.18.0
为例。
安装前请确认 443 端口未被占用,如果 443 端口已使用,请在安装证书时绑定其他端口。
获取证书
- 我们为您签发证书后将会给您颁发证书文件(.zip)压缩格式,压缩包中有四个文件夹分别对应四种证书格式:Tomcat、Nginx、IIS、Apache;Nginx 服务器需要用到 Nginx 文件夹内的证书。
- Nginx文件夹中将包含两个文件,
domain_com_integrated.crt
证书文件domain_com.key
私钥文件
安装SSL证书
- 将已获取到的
domain_com_integrated.crt
证书文件、domain_com.key
私钥文件从本地目录拷贝到Nginx 服务器的/etc/nginx/ssl
目录下。
- 若
/etc/nginx/ssl
目录不存在,可以通过mkdir -p /etc/nginx/ssl
命令创建 - 不同安装方式之间目录位置可能存在差异,请根据实际情况为准。
- 编辑 Nginx 根目录下的
nginx.conf
文件。修改内容如下:
nginx.conf
server {
listen 443 ssl;
#填写自己的域名,多个域名用空格隔开
server_name racent.com;
#填写证书文件的相对路径或绝对路径
ssl_certificate cloud.tencent.com_bundle.crt;
#填写私钥文件的相对路径或绝对路径
ssl_certificate_key cloud.tencent.com.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4:!DH:!DHE;
ssl_prefer_server_ciphers on;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
}
注意
由于版本问题,配置文件可能存在不同的写法。例如:Nginx 版本为 nginx/1.15.0
以下请使用 listen 443
和 ssl on
代替 listen 443 ssl
。
修改后保存配置文件并执行以下命令:
nginx -t #验证配置文件是否正确
nginx -s reload #重载 Nginx
测试SSL证书
在浏览器地址栏输入绑定SSL证书的域名,测试您的 SSL 证书是否安装成功。如果成功,则浏览器地址栏会显示一个安全锁标志,点击可查看证书信息。
HTTP 自动跳转 HTTPS 的安全配置(可选)
如果您需要将 HTTP 请求自动重定向到 HTTPS
,您可以通过以下操作设置:
- 使用Nginx重定向功能,在HTTP的
server
中增加return 301 https://$host$request_uri;
,即可将HTTP
请求重定向为HTTPS
。修改如下内容:
server {
listen 80;
#把http的域名请求转成https
return 301 https://$host$request_uri;
}
- 重新启动 Nginx 服务器即可使用域名访问,实现
HTTP
自动跳转HTTPS
。