Nginx 配置 SSL(HTTPS)

记录如何给网站配置 HTTPS

获取免费的 SSL 证书

这个我是从阿里的数字证书管理服务申请的一年免费 SSL 证书。一年可以免费申请 20 张免费证书。

申请好之后,还是在这个页面点击「创建 20 / 20」按钮,创建一个证书,并点击操作栏的「申请证书」正式申请你的证书。

在申请页面中,输入以下几个必填信息(以实际页面为主):

  • 证书绑定域名
  • 域名验证方式
  • 联系人
  • 所在地
  • 密钥算法
  • CSR 生成方式

然后点击下一步,在对应的阿里云DNS控制台添加已生成的 DNS 解析记录。这个一般人家都会帮你生成好,等5分钟左右,回到证书申请页面,点击「验证」即可。

等待验证通过之后,点击「提交审核」即可。

完成上述步骤之后,我们点击证书列表操作栏中的「部署」按钮,跳到「证书部署」页面:

  • 选择资源列表-云服务器 ECS
  • 在自己的 ECS 服务器上进行部署(点击「部署」按钮)
  • 自定义证书路径和私钥路径
  • 点击确定之后,就会在你的 ECS 上生成对应的证书及其私钥

如果不知道如何配置,可以点击右上角的「帮助文档」,傻瓜式粘贴复制。

如果在确认之后,一直迟迟没有好,那可能出现了 BUG,我查看了接口之后发现接口报错了,然后登到服务器之后又发现,证书已经OK了。

接下来我们就是需要去配置 Nginx 了。

在配置之前我们需要知道以下几点:

  1. 确保 Nginx 是已经安装过 https 的模块(这个不安装,在配置了 ssl 后重新 reload 也会提示)
  2. 确保 ssl 部分的配置正确
  3. 可以使用 nginx -t 测试

如果我们当安装 nginx 之初没有安装 ssl 模块,那么需要进到 nginx 的安装包内进行安装:

shell 复制代码
 ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module

为什么要进入到安装包,是因为 configure 就在安装包内,当然也可以根据路径来安装,都可以的

安装好之后,需要再编译一次:

shell 复制代码
make

然后这里我们最好是备份已有的 nginx.conf 文件,防止后续操作时被覆盖掉。

shell 复制代码
cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak

再然后,复制刚编译生成的配置覆盖原有的配置:

shell 复制代码
cp ./objs/nginx /usr/local/nginx/sbin/

我们再回到 nginx.conf 中添加 ssl 部分的配置:

conf 复制代码
server {
    listen       443 ssl;
    server_name  xxxx;
    ssl_certificate       cert/wenabc.pem;
    ssl_certificate_key   cert/wenabc.key;
	ssl_session_timeout 5m;
    ssl_ciphers  HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers on;
    location / {
        root /home/;
    	index  index.html index.htm;
    }
}

最后执行:

shell 复制代码
ngixn -s reload

大功告成。

踩坑

首先就是没有安装 ssl 模块,导致卡了半天,安装好之后就比较顺利。

第二就是在替换 nginx 二进制文件时,提示原来的程序正在执行,那这个就是需要先 stop 掉当前的 nginx,在替换之后,重新执行一下 ./nginx 即可。

相关推荐
Shi_haoliu15 小时前
SolidTime 在 Rocky Linux 9.5 上的完整部署流程
linux·运维·nginx·postgresql·vue·php·laravel
zhengxianyi5151 天前
vue-cli build, vite build 生产部署刷新或弹窗404,页面空白修复方法
前端·javascript·vue.js·nginx·生产部署
zhengxianyi5151 天前
vite build 发布到nginx二级目录——将yudao-ui-go-view打包、部署到big目录下
vue.js·nginx·vite·前后端分离·打包·ruoyi-vue-pro优化·部署运维
JH30731 天前
openfeign vs nginx 负载均衡对比
运维·nginx·负载均衡
爱吃山竹的大肚肚1 天前
Nginx 最核心和常用的命令
java·运维·服务器·前端·nginx
姜太小白1 天前
【Nginx】鉴权接口通过后,导出或下载接口无响应
运维·网络·nginx
老友@1 天前
Docker Nginx HTTPS 实战:Let’s Encrypt SSL 证书生成与自动续期
运维·nginx·docker·https·证书·ssl
@22062 天前
银河麒麟系统离线环境下用docke方式部署(Postgres、Nginx、Redis、JDK)
运维·数据库·redis·nginx
戈壁老孙2 天前
使用Nginx实现动态后端服务切换:一套配置管理多环境
运维·nginx
天天天天学习丶2 天前
Nginx 域名解析后默认打开其他项目问题解决方案
nginx