无法在 Fedora 27 上从 python3 导入 psycopg2

Cannot import psycopg2 from python3 on fedora 27

我刚刚升级到 Fedora 27,但无法让 psycopg2 工作。

我非常感谢任何人可以提供的帮助。

作为一个简单的测试用例,我一直在执行
>>> import psycopg2
在互动 shell。这适用于 Python 2.7,但不适用于 Python 3.x.

使用 Python 3.4 和 3.5,我收到消息:

Traceback (most recent call last): File "", line 1, in ImportError: No module named 'psycopg2'

Python 3.6,我看到:

Traceback (most recent call last): File "", line 1, in File "/home/jazcap53/.local/lib/python3.6/site-packages/psycopg2/init.py", line 50, in from psycopg2._psycopg import ( # noqa ImportError: /home/jazcap53/.local/lib/python3.6/site-packages/psycopg2/.libs/libresolv-2-c4c53def.5.so: symbol __res_maybe_init, version GLIBC_PRIVATE not defined in file libc.so.6 with link time reference

我从 DVD-ROM 安装了 Fedora 27。我发现 psycopg2 包位于 /usr/lib64/python2.7/site-packages

/home/jazcap53/.local/lib/python3.6/site-packages

我的 Python 软件包都包含在 Fedora 中,或者通过 dnf 安装。他们是:

python3-3.6.3-2.fc27.x86_64
python35-3.5.4-1.fc27.x86_64
python34-3.4.7-1.fc27.x86_64
python2-2.7.14-2.fc27.x86_64

我安装的一些可能相关的软件包是:

python2-devel-2.7.14-2.fc27.x86_64
python3-devel-3.6.3-2.fc27.x86_64
libpqxx-1:5.0.1-2.f27.x86_64
libpqxx-devel-1:5.0.1-2.f27.x86_64
libgcc-7.2.1-2.fc27.x86_64
postgresql-devel-9.6.6-1.fc27.x86_64

P.S.: 如果我在错误的地方问这个问题,请指引我到正确的地方。

编辑: 我注意到:

/usr/lib64/python2.7/site-packages/
包含子目录
psycopg2
psycopg2-2.7.3-py2.7.egg-info

但是

/usr/lib64/python3.4/site-packages/
/usr/lib64/python3.5/site-packages/
不包含任何与 psycopg2

相关的内容

/usr/lib64/python3.6/site-packages/
包含子目录
psycopg2-2.7.3-py3.6.egg-info
但不是 psycopg2 本身

您可能已经注意到,Python 的每个版本都有自己的包层次结构。因此,在 Python 3.6 上安装将无法让您访问 3.4 和 3.5。

话虽如此,Python 3.6 的系统标准库似乎存在一些问题。一种解决方案是不使用二进制文件进行安装,如下所示:

python3.6 -m pip uninstall psycopg2
python3.6 -m pip install --no-binary :all: psycopg2

要在 3.4 和 3.5 上安装 psycopg2,您需要 运行 这些有或没有 --no-binary 选项:

python3.4 -m pip install psycopg2
python3.5 -m pip install psycopg2

如果您有自动安装/docker 安装,您需要确保将以下行添加到 requirements.txt 以确保 psycopg2 从源安装,而不是使用二进制文件,否则您将继续在部署时遇到上述问题。

psycopg2>=2.7,<2.8 --no-binary psycopg2