humid1ch blogs

本篇文章

手机用户建议
PC模式 或 横屏
阅读


Linux使用问题 2023 年 7 月 20 日

[Linux] CentOS7 中 pip3 install 可能出现的 ssl 问题

执行pip3 install, 可能会警告 WARNING: pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available.

由于解决问题之后, 才写的博客, 所以没有图片记录.

尽量描述清楚一些

今天写代码的时候, 突然发现 文件里用了#define定义宏之后, coc.nvimcoc-clangd补全就用不了
:checkhealth了一下, 发现nvim忘记支持python3
尝试pip3 install neovim的时候, 发现会警告然后安装失败.
截图就没有了, 警告第一句大概是:
WARNING: pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available.
大概的意思是Python安装没有编译支持 SSL/TLS 加密的模块, 如果没有 SSL/TLS 支持, 就可能无法安装某些需要安全连接的Python
然后, 就开始踩坑了

踩坑

先尝试重新编译安装python3:
# 没有解决问题, 不要尝试
# 去到python源码路径下 
make clean
./configure --prefix=/usr/local/python3 --with-ssl
make
make install
然后make编译出问题:
Could not build the ssl module!
Python requires an OpenSSL 1.0.2 or 1.1 compatible libssl with X509_VERIFY_PARAM_set1_host().
LibreSSL 2.6.4 and earlier do not provide the necessary APIs
出现这个的原因是, CentOS7执行sudo yum install openssl-devel安装的openssl版本是1.0.2太老了

然后我又去下载了openssl1.1.1的源码 并且按照官网文档进行了编译安装.
# 官方文档安装步骤
wget https://www.openssl.org/source/openssl-1.1.1g.tar.gz
tar zxvf openssl-1.1.1g.tar.gz
cd openssl-1.1.1g
./config --prefix=/usr/local/openssl1.1.1 --openssldir=/usr/local/openssl1.1.1 no-ssl2
make
make install

# 安装完成之后, 还按照官方文档 添加了环境变量
export PATH=/usr/local/openssl1.1.1/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/openssl1.1.1/lib
export LC_ALL="en_US.UTF-8"
export LDFLAGS="-L /usr/local/openssl1.1.1/lib -Wl,-rpath,/usr/local/openssl1.1.1/lib"
然后, 重启了服务器, 执行openssl version会显示OpenSSL 1.1.1g 21 Apr 2020
再次去尝试编译安装python3:
# 没有解决问题, 不要尝试
# 去到python源码路径下 
make clean
./configure --prefix=/usr/local/python3 --with-ssl=/usr/local/openssl-1.1.1
make
make install
然而, 并没有解决问题.
make还是会出现相同的问题:
Could not build the ssl module!
“Python requires an OpenSSL 1.0.2 or 1.1 compatible libssl with X509_VERIFY_PARAM_set1_host().`
LibreSSL 2.6.4 and earlier do not provide the necessary APIs
但是, 明明已经安装了openssl1.1.1而且也指定了openssl1.1.1的库和软件
也把makefile里所有的/usr/local/openssl改成了/usr/local/openssl1.1.1
但还是没用.

解决

因为补全很重要, 所以一直在找怎么解决
终于, 在这篇提问中找到了解决方案:
提问的某楼中提到, CentOS7可以直接用yum安装openssl1.1.1:
sudo yum install openssl11 openssl11-devel
mkdir /usr/local/openssl11
cd /usr/local/openssl11
ln -s /usr/lib64/openssl11 lib
ln -s /usr/include/openssl11 include
可以直接安装openssl1.1.1, 并将相应的库和包含 软连接到了 /usr/local/openssl11/lib/usr/local/openssl11/include
然后我再次 尝试重新编译安装python3:
# 去到python源码路径下 
make clean
./configure --prefix=/usr/local/python3 --with-ssl=/usr/local/openssl11
make
这一次make没有再报ssl相关错误:
然后make installpython3安装
安装成功之后, 进行软连接:
# 备份 python 和 pip
mv /usr/bin/python /usr/bin/python.bak
mv /usr/bin/python3 /usr/bin/python3.bak
mv /usr/bin/pip3 /usr/bin/pip3.bak
# 建立软连接
ln -s /usr/local/python3/bin/python3 /usr/bin/python
ln -s /usr/local/python3/bin/python3 /usr/bin/python3
ln -s /usr/local/python3/bin/pip3 /usr/bin/pip3
然后 尝试执行pip3 install neovim:
没有再报 WARNING: pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available. 警告.
然后打开neovim执行:checkhealth
可以看到, python3成功被支持, coc.nvim也没有配置错误:
问题解决~
感谢阅读~
版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)

作者: 哈米d1ch 发表日期:2023 年 7 月 20 日