1.nginx安装
1.依赖安装,执行以下命令
yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
2.nginx下载安装,执行以下命令
tar -zxvf nginx-1.20.2.tar.gz #解压nginx安装包,没有官网下载
cd nginx-1.20.2 #进入到解压的安装包里面
./configure --with-http_ssl_module #注意后面的参数必须要,不然无法使用ssl
make & make install
3.查看是否安装成功,执行以下命令
cd /usr/local/nginx/sbin/ # nginx默认安装的位置,安装时有指定,则cd到指定安装位置
./nginx -v #查看安装版本,出现正确信息则安装成功
2.域名申请
阿里云域名申请网址 1.购买域名
2.解析域名
阿里云域名控制台
3.ssl免费证书申请
证书申请地点 1.申请证书
2.创建需要的证书
阿里云证书控制台
4.配置nginx(参考上面的帮助信息)
1.将下载的证书上传服务器上
2.将下载的证书放到以下指定位置(可选),执行以下命令
yum -y install unzip #有则不需要安装
unzip 7409704_www.zengwenbo.top_nginx.zip #解压.zip文件
mv 7409704_www.zengwenbo.top.key /usr/local/nginx/conf/cert/
mv 7409704_www.zengwenbo.top.pem /usr/local/nginx/conf/cert/ #将秘钥移动到该位置,可选
3.编辑nginx的配置文件
执行以下命令
vim /usr/local/nginx/conf/nginx.conf
4.替换以下内容(注意换成自己的域名和自己秘钥存储位置)
#以下属性中,以ssl开头的属性表示与证书配置有关。
server {
listen 443 ssl;
#配置HTTPS的默认访问端口为443。
#如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
#如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
server_name www.zengwenbo.top; #需要将yourdomain替换成证书绑定的域名。
root html;
index index.html index.htm;
ssl_certificate cert/7409704_www.zengwenbo.top.pem; #需要将cert-file-name.pem替换成已上传的证书文件的名称。
ssl_certificate_key cert/7409704_www.zengwenbo.top.key; #需要将cert-file-name.key替换成已上传的证书私钥文件的名称。
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
#表示使用的加密套件的类型。
ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; #表示使用的TLS协议的类型。
ssl_prefer_server_ciphers on;
location / {
root html; #Web网站程序存放目录。
index index.html index.htm;
}
}
server {
listen 80;
server_name www.zengwenbo.top; #需要将yourdomain替换成证书绑定的域名。
rewrite ^(.*)$ https://$host$1; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
location / {
index index.html index.htm;
}
}
5.执行以下命令启动nginx
cd /usr/local/nginx/sbin/
./nginx -t #检查配置文件是否有问题
./nginx #启动nginx
6.结合轮询的配置
upstream backend {
server 120.79.141.136:8888;
}
#以下属性中,以ssl开头的属性表示与证书配置有关。
server {
listen 443 ssl;
#配置HTTPS的默认访问端口为443。
#如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
#如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
server_name www.zengwenbo.top; #需要将yourdomain替换成证书绑定的域名。
root html;
index index.html index.htm;
ssl_certificate cert/7409704_www.zengwenbo.top.pem; #需要将cert-file-name.pem替换成已上传的证书文件的名称。
ssl_certificate_key cert/7409704_www.zengwenbo.top.key; #需要将cert-file-name.key替换成已上传的证书私钥文件的名称。
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
#表示使用的加密套件的类型。
ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; #表示使用的TLS协议的类型。
ssl_prefer_server_ciphers on;
location / {
# root html; #Web网站程序存放目录。
proxy_pass http://backend;
index index.html index.htm;
}
}
server {
listen 80;
server_name www.zengwenbo.top; #需要将yourdomain替换成证书绑定的域名。
rewrite ^(.*)$ https://$host$1; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
location / {
index index.html index.htm;
}
}