问题
CentOS 7 默认安装的 nginx 依赖 openssl 版本为 v1.0.2k (需要手动安装最新版 nginx v1.20.2,支持openssl v1.0.2+)
uwsgi 默认依赖的 openssl 版本为 v1.1.1
mycli (cryptography,这个库在 paramiko 里面用到
) 支持的 openssl 版本为 v1.1.0, v1.1.1,参见 https://cryptography.io/en/latest/installation/
所以 openssl 的版本问题会造成上述软件冲突。
解决方案
0) 卸载默认安装的 openssl
$ sudo yum remove openssl
1) 手动安装 openssl v1.1.1
从 https://www.openssl.org/source/old/1.1.1/openssl-1.1.1.tar.gz 下载安装包,编译安装,
$ tar --gzip -xf openssl-1.1.1.tar.gz
$ cd openssl-1.1.1
$ ./config
$ make
$ sudo make install
创建 openssl 的系统软链接,
$ sudo ln -fs /usr/local/lib64/libssl.so.1.1 /usr/lib64/libssl.so.1.1
$ sudo ln -fs /usr/local/lib64/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1
2) 手动安装 nginx
从 https://nginx.org/download/nginx-1.20.2.tar.gz 下载最新稳定版的 nginx,编译安装,
$ tar --gzip -xf nginx-1.20.2.tar.gz
$ cd nginx-1.20.2
$ ./configure
$ make
$ sudo make install
# 如果要删除这个安装版本,则先进入此文件夹,然后运行
$ sudo make uninstall
安装完成后,默认安装路径在 /usr/local/nginx/sbin/nginx,默认配置文件路径在 /usr/local/nginx/conf。
创建并编辑 nginx 的开机启动文件 /lib/systemd/system/nginx.service,内容为,
[Unit]
Description=The NGINX HTTP and reverse proxy server
After=syslog.target network-online.target remote-fs.target nss-lookup.target
Wants=network-online.target
[Service]
Type=forking
PIDFile=/run/nginx.pid
ExecStartPre=/usr/sbin/nginx -t
ExecStart=/usr/sbin/nginx
ExecReload=/usr/sbin/nginx -s reload
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
因为上述文件 nginx 可执行程序为 /usr/sbin/nginx,所以需要创建软链接如下,
$ sudo ln -fs /usr/local/nginx/sbin/nginx /usr/sbin/nginx
手动安装的 nginx 的配置文件路径为 /usr/local/nginx/conf/nginx.conf,根据项目需求,编辑此文件即可。
注意,因为上述开机自启动文件 nginx.service 文件中已经制定 PIDFile=/run/nginx.pid,所以需要在 nginx.conf 中做同样的配置,如下,
... pid /run/nginx.pid; ...
设置 nginx 的开机启动 ,
$ sudo systemctl enable nginx.service
重启电脑。
(完)