我正在尝试使用RStudio Server v1.2.5042和使用reticulate
创建的自定义环境,在CentOS 7.8系统上使用R软件包conda
。当我使用reticulate
启动Python作业时,出现错误,提示某些系统库不是正确的版本,特别是libstdc++.so.6
和libz.so.1
。
首先,我意识到CentOS 7.8有点旧,并且某些问题可以通过升级OS来解决,但是在这种情况下,这不是一个选择。
conda
环境可以正常工作,我可以在终端窗口中运行目标Python脚本,而不会出现任何错误。在使用reticulate
的RStudio中,此刻的代码非常简单:
library(reticulate)
use_condaenv('test')
py_run_file('test_script.py')
运行脚本时,出现以下错误:
ImportError: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by /home/<user>/.conda/envs/test/lib/python3.8/site-packages/scipy/_lib/_uarray/_uarray.cpython-38-x86_64-linux-gnu.so)
当我查看/usr/lib64
目录时,会发现libstdc++.so
,但是运行strings libstdc++.so | grep ^GLIBC | sort
则表明它确实不支持版本GLIBCXX 3.4.21
。没什么好奇怪的如果导航到/home/<user>/.conda/envs/test/lib
目录,则会找到libstdc++.so.6
的另一个副本,并且该副本确实支持版本GLIBCXX 3.4.21
。因此,正确的conda
环境目录中存在该库的正确版本,但是由于某些原因RStudio和reticulate
找不到它。
我尝试将LD_LIBRARY_PATH
更改为首先列出conda
环境目录,但这不起作用。我发现了一段漫长的讨论here,指出LD_LIBRARY_PATH
并不是一个好的解决方法,除非它是在RStudio进程初始化之前设置的。 (然后就使用哪个版本的Python进行了切线。)就我的情况而言,可能有多个conda
环境要支持,并且不可能知道在任何给定的会话中哪个将处于活动状态,并且任何给定的用户我都会使用不同/多个环境。我宁愿不要尝试将所有conda
环境协调成一个大型超级环境。
我还验证了Python版本和其他库的正确设置:
python: /home/<user>/.conda/envs/test/bin/python
libpython: /home/<user>/.conda/envs/test/lib/libpython3.8.so
pythonhome: /home/<user>/.conda/envs/test:/home/<user>/.conda/envs/test
version: 3.8.5 (default, Aug 5 2020, 08:36:46) [GCC 7.3.0]
numpy: /home/<user>/.conda/envs/test/lib/python3.8/site-packages/numpy
numpy_version: 1.19.1
NOTE: Python version was forced by use_python function
通过重置/usr/lib64
中的链接使其指向conda
目录中的副本,我可以使其运行。尽管这可以使其在该实例中正常工作,但我不确定我是否想将这样的修复程序推向生产环境。我的猜测是,如果我在所有conda
环境中链接到该库中包含性最强的版本,并且该版本完全支持系统级库支持的所有版本,那么一切都会很好,但这听起来像是黑客,充其量。
如果有人找到了一个好的解决方案,我希望知道详细信息。