Python 安装 PyICU 时出现分段错误

Segmentation fault with Python with install of PyICU

我一直在尝试安装一个名为 Polyglot 的 Python 库,而该库又需要 PyICU,这是我遇到麻烦的根源。经过大量的错误追逐之后,我能够在我的 EC2 实例上安装 PyICU。但是,当 运行 Polyglot 和 PyICU 时,我得到以下错误:

Traceback (most recent call last):
  File "/mnt/data/anaconda3/bin/polyglot", line 11, in <module>
    load_entry_point('polyglot==16.7.4', 'console_scripts', 'polyglot')()
  File "/mnt/data/anaconda3/lib/python3.6/site-packages/pkg_resources/__init__.py", line 487, in load_entry_point
    return get_distribution(dist).load_entry_point(group, name)
  File "/mnt/data/anaconda3/lib/python3.6/site-packages/pkg_resources/__init__.py", line 2728, in load_entry_point
    return ep.load()
  File "/mnt/data/anaconda3/lib/python3.6/site-packages/pkg_resources/__init__.py", line 2346, in load
    return self.resolve()
  File "/mnt/data/anaconda3/lib/python3.6/site-packages/pkg_resources/__init__.py", line 2352, in resolve
    module = __import__(self.module_name, fromlist=['__name__'], level=0)
  File "/mnt/data/anaconda3/lib/python3.6/site-packages/polyglot/__main__.py", line 16, in <module>
    from icu import Locale
  File "/mnt/data/anaconda3/lib/python3.6/site-packages/icu/__init__.py", line 37, in <module>
    from _icu import *
ImportError: /lib64/libc.so.6: version `GLIBC_2.18' not found (required by /home/linuxbrew/.linuxbrew/lib/libstdc++.so.6)

为了解决上述问题,我执行了以下步骤:

mkdir ~/glibc_install; cd ~/glibc_install 
wget http://ftp.gnu.org/gnu/glibc/glibc-2.18.tar.gz
tar zxvf glibc-2.18.tar.gz
cd glibc-2.18
mkdir build
cd build
../configure --prefix=/opt/glibc-2.18
make -j4
make install
export LD_LIBRARY_PATH=/opt/glibc-2.18/lib

但是当我简单地 运行 Python 时,我立即遇到了分段错误。

请注意,我在 AWS EC2 上使用 Red Hat 7.1.2-2。

如有任何帮助,我们将不胜感激!

如果您只是想试验一下,可以使用 Red Hat Enterprise Linux 8 的测试版,它随 glibc 2.28 一起提供,因此提供 GLIBC_2.18 符号。

如果您 运行 Python 使用显式加载程序调用(例如 /opt/glibc-2.18/lib64/ld-linux-x86-64.so.2 python …),分段错误将消失。如果你想朝这个方向发展,你真的应该使用仍在上游维护的更新版本的 glibc(例如此时的 glibc 2.28),理想情况下是来自 Git 的发布分支,因为它有许多反向端口来修复各种问题错误。

但下一个问题是您正试图用自定义副本替换系统 libstdc++ 库。这可能会破坏系统软件和第三方应用程序。

您应该尝试获取您要安装的软件的副本,该软件是为 Red Hat Enterprise Linux 7(甚至是 Red Hat Enterprise Linux 6)构建的。它会更容易使用,并避免所有这些问题。如果软件是使用比 C++98 更新的 C++ 标准编写的,则可以使用 Developer Toolset。它有一个混合链接模型,静态链接更新的 C++ 标准所需的支持代码,同时其余部分仍然使用系统 libstdc++,以最大限度地提高互操作性。