Nginx配置SSL证书时——nginx:[emerg]unknown directive ssl错误

- 日理万妓 2022-03-12 13:24 451阅读 0赞
  1. 一、引言
  2. 当我们的Linux服务器上当中发布了web项目,有时候需要配置一个SSL证书,这样表示你这个网站还比较正式哈哈哈。当我把证书下载好,把nginx.conf配置好,简直就是万事俱备,只欠重启。结果一重启,duang~出错了。
  3. nginx:[emerg]unknown directive ssl,就是这个错误提示
  4. 因为我们配置这个SSL证书需要引用到nginx的中SSL这模块,然而我们一开始编译的Nginx的时候并没有把SSL模块一起编译进去,所以导致这个错误的出现。
  5. 二、错误解决步骤
  6. 既然在安装的时候没有编译ssl,难道把nginx卸载重新安装一次?不不不,我们只需要在原有的基础上添加ssl模块就行了。
  7. 步骤一:我们先来到当初下载nginx的包压缩的解压目录,如果你是看小编写的教程安装的,解压目录应该在“/usr/loacl/src/”,绝大多数应该都是在这个目录下的,已经是一种规范了。
  8. 步骤二:来到解压目录下后,按顺序执行一下命令:
  9. 命令1、./configure --with-http_ssl_module //重新添加这个ssl模块
  10. 注意如果没有出现错误,则直接看命令2即可
  11. 执行以上一条命令出现这个错误(./configure:错误:SSL模块需要OpenSSL库。),原因是因为缺少了OpenSSL,那我们再来安装一个即可执行:yum -y install openssl openssl-devel
  12. 等待OpenSSL的安装完成后,再执行./configure ,最后在执行” 命令1" 即可。
  13. 命令2、执行make命令,但是不要执行make install,因为make是用来编译的,而make install是安装,不然你整个nginx会重新覆盖的。
  14. 命令3、在我们执行完做命令后,我们可以查看到在nginx解压目录下,objs文件夹中多了一个nginx的文件,这个就是新版本的程序了。首先我们把之前的nginx先备份一下,然后把新的程序复制过去覆盖之前的即可。
  15. cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak
  16. cp objs/nginx /usr/local/nginx/sbin/nginx
  17. 命令4,最后我们来到Nginx安装目录下,来查看是否有安装ssl模块成功。执行./sbin/nginx -V即可看到如下图:
  18. 三、最后如果出现如上图,则SSL模块添加到Nginx的编译好了,这次重新启动则OK了。

发表评论

表情:
评论列表 (有 0 条评论,451人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Nginx 配置 ssl 证书

    > 在部署线下测试环境时浏览器会自动将http替换成https,又因为测试环境没有证书经常会导致跳转错误,所以自己配置一个ssl证书就可以避免这个问题。 > 下面记录我在M