在当前的网络环境中,为了保障网站的用户信息安全,使用SSL证书已经成为了一个标配。Nginx是一个高性能的Web服务器软件,在使用Nginx进行Web服务的时候,安装一个SSL证书也是非常有必要的。在本文中,我们将详细介绍如何安装SSL证书的步骤及注意事项。
nginx安装ssl证书介绍
一、生成证书
首先,需要先生成证书文件。可以通过许多工具来创建SSL证书,如openssl、certbot等等。这里我们以certbot为例,通过命令行在服务器中完成证书生成。
安装certbot:
yum install certbot
获取ssl证书:
certbot certonly --nginx -d example.com
其中example.com为你的域名,请替换为你自己的域名。
此时,会有一系列的提示信息,按照提示进行操作即可。在完成后,你将获得3个文件:
- privkey.pem: 私钥
- fullchain.pem: 公钥和根证书,并在其中排列。
- chain.pem: 根证书
二、安装证书
安装nginx
在安装nginx之前,请确保先安装好openssl、pcre、zlib等依赖的安装包,在此不多赘述。
yum install nginx
修改nginx配置文件
在nginx的配置文件中增加ssl证书的路径,以及启用SSL服务。
server {
listen 443 ssl;
server_name example.com;
ssl_certificate /path/to/fullchain.pem;
ssl_certificate_key /path/to/privkey.pem;
ssl_prefer_server_ciphers on;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
add_header Strict-Transport-Security "max-age=31536000; includeSubdomains; preload;";
}
在以上代码中,listen 443 ssl启用了Web服务的SSL服务端口,server_name指定域名,ssl_certificate和ssl_certificate_key指定证书的路径,除此之外用的都是SSL的标准配置。
注意:nginx中的http模块需要启用ssl模块。
http {
server_tokens off;
include mime.types;
default_type application/octet-stream;
sendfile on;
gzip on;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
server {
listen 80;
server_name example.com;
return 301 https://$server_name$request_uri;
}
}
重启nginx服务
重启nginx服务,若没有出现错误,那么恭喜你已经完成了SSL证书的安装。
三、注意事项
- 请保证在生成证书的时候输入正确的域名,否则无法通过SSL证书验证。
- 在nginx配置文件中指定证书文件时,必须是绝 对路径。
- SSL服务需要占用独立的端口(一般为443),不要与其他Web服务共用。
- 使用SSL协议时,使用其他传输协议的API需要做相应的修改,以配合SSL协议工作。
在安装Nginx SSL证书的时候,需要先生成证书,然后修改Nginx的配置文件,再重启Nginx服务即可。在整个过程中,注意事项必须要遵守,才能保证SSL证书能够正常使用,确保用户信息的安全。