Flink flink中写python-udf , 需要用requests包,import requests会报错怎么解决?:
File "/usr/local/python3/lib/python3.7/site-packages/requests/init.py", line 43, in
import urllib3
File "/usr/local/python3/lib/python3.7/site-packages/urllib3/init.py", line 42, in
"urllib3 v2.0 only supports OpenSSL 1.1.1+, currently "
ImportError: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the 'ssl' module is compiled with 'OpenSSL 1.0.2k-fips 26 Jan 2017'. See: https://github.com/urllib3/urllib3/issues/2168
在 Flink 中使用 Python UDF 时遇到 requests
包的导入问题,提示 OpenSSL 版本不兼容。这是因为你的系统中安装的 OpenSSL 版本与 urllib3
库要求的版本不符。
要解决这个问题,可以尝试以下方法:
升级 OpenSSL:
如果你的操作系统支持,你可以尝试升级系统中的 OpenSSL 到一个更高版本(至少 1.1.1+)。请注意这可能需要管理员权限,并且可能会影响到其他依赖于当前版本 OpenSSL 的应用程序。所以,在升级之前,请确保你了解并接受潜在的风险。
降级 urllib3:
如果你不能或不想升级 OpenSSL,你可以尝试降级 urllib3
到一个与你的 OpenSSL 版本兼容的版本。打开命令行,进入虚拟环境(如果有的话),然后执行以下命令来安装特定版本的 urllib3
:
pip install urllib3==<compatible_version>
其中 <compatible_version>
是一个与你的 OpenSSL 版本兼容的 urllib3
版本号。请查阅 urllib3
文档以找到合适的版本。
更换 HTTP 库:
如果以上方法都无法解决问题,你可以考虑更换一个不同的 HTTP 库来替代 requests
。例如,httpx
或 aiohttp
等库都是不错的选择。这些库可能对 OpenSSL 版本的要求不同,或者有更好的兼容性。
这个错误表明你的Python环境中的OpenSSL版本太旧,不支持urllib3 v2.0。urllib3是一个用于处理HTTP请求的库,requests库依赖于它。
要解决这个问题,你需要更新你的OpenSSL版本到1.1.1+。以下是可能的步骤:
升级OpenSSL:首先需要确定你的操作系统。如果你在Linux上运行,可以使用以下命令来更新OpenSSL:
对于Ubuntu/Debian:
sudo apt-get update
sudo apt-get install libssl-dev
对于CentOS/RHEL:
sudo yum update openssl-devel
如果你不在Linux上,或者这些命令不起作用,请查阅你的操作系统的文档以了解如何更新OpenSSL。
重新安装Python:升级完OpenSSL后,你需要重新编译和安装Python以确保它链接到新的OpenSSL库。你可以从源代码安装Python,或者使用像pyenv这样的工具来管理多个Python版本。
验证版本:安装新版本的Python后,你可以通过以下命令检查OpenSSL版本:
import ssl
print(ssl.OPENSSL_VERSION)
如果版本已经更新为1.1.1+,你应该就不会再遇到那个错误了。
重新安装requests:最后,你可能还需要重新安装requests库以确保它正确地与新版本的OpenSSL一起工作。
pip uninstall requests
pip install requests
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
实时计算Flink版是阿里云提供的全托管Serverless Flink云服务,基于 Apache Flink 构建的企业级、高性能实时大数据处理系统。提供全托管版 Flink 集群和引擎,提高作业开发运维效率。