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包,import requests报错为什么?[阿里云]
「点点赞赏,手留余香」
还没有人赞赏,快来当第一个赞赏的人吧!
在 Flink 中使用 Python UDF 时遇到
requests
包的导入问题,提示 OpenSSL 版本不兼容。这是因为你的系统中安装的 OpenSSL 版本与urllib3
库要求的版本不符。要解决这个问题,可以尝试以下方法:
升级 OpenSSL:
如果你的操作系统支持,你可以尝试升级系统中的 OpenSSL 到一个更高版本(至少 1.1.1+)。请注意这可能需要管理员权限,并且可能会影响到其他依赖于当前版本 OpenSSL 的应用程序。所以,在升级之前,请确保你了解并接受潜在的风险。
降级 urllib3:
如果你不能或不想升级 OpenSSL,你可以尝试降级
urllib3
到一个与你的 OpenSSL 版本兼容的版本。打开命令行,进入虚拟环境(如果有的话),然后执行以下命令来安装特定版本的urllib3
:其中
是一个与你的 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:
对于CentOS/RHEL:
如果你不在Linux上,或者这些命令不起作用,请查阅你的操作系统的文档以了解如何更新OpenSSL。
重新安装Python:升级完OpenSSL后,你需要重新编译和安装Python以确保它链接到新的OpenSSL库。你可以从源代码安装Python,或者使用像pyenv这样的工具来管理多个Python版本。
验证版本:安装新版本的Python后,你可以通过以下命令检查OpenSSL版本:
如果版本已经更新为1.1.1+,你应该就不会再遇到那个错误了。
重新安装requests:最后,你可能还需要重新安装requests库以确保它正确地与新版本的OpenSSL一起工作。
升级Open SSL版本吧,版本低了。此回答整理自钉群“实时计算Flink产品交流群”