Python 在 ldconfig -p 找到的 /usr/lib/x86_64-linux-gnu 中找不到库

Python not finding library in /usr/lib/x86_64-linux-gnu that ldconfig -p does find

我正在尝试使用 python 模块 cairocffi。我在 x86-64 上使用 Debian (Stretch),所以我安装了 apt 包 libcairo2-dev 并使用 pip 安装了 cairocffi python 包。这一切都很顺利。但是当我尝试导入它时,它无法加载模块:

$ python -c "import cairocffi; print('OK')"
Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "/usr/local/lib/python2.7/dist-packages/cairocffi/__init__.py", line 46, in <module>
    cairo = dlopen(ffi, 'cairo', 'cairo-2')
  File "/usr/local/lib/python2.7/dist-packages/cairocffi/__init__.py", line 43, in dlopen
    raise OSError("dlopen() failed to load a library: %s" % ' / '.join(names))
OSError: dlopen() failed to load a library: cairo / cairo-2

但是,ldconfig 确实知道 libcairo.so:

$ sudo ldconfig -p | grep cairo
        libpangocairo-1.0.so.0 (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libpangocairo-1.0.so.0
        libpangocairo-1.0.so (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libpangocairo-1.0.so
        libcairo.so.2 (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libcairo.so.2
        libcairo.so (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libcairo.so
        libcairo-script-interpreter.so.2 (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libcairo-script-interpreter.so.2
        libcairo-script-interpreter.so (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libcairo-script-interpreter.so
        libcairo-gobject.so.2 (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libcairo-gobject.so.2
        libcairo-gobject.so (libc6,x86-64) => /usr/lib/x86_64-linux-gnu/libcairo-gobject.so

当我 运行 python 修改 LD_LIBRARY_PATH 时,它起作用了:

$ LD_LIBRARY_PATH=/usr/lib/x86_64-linux-gnu python -c "import cairocffi; print('OK')"
OK

为了可扩展性和可维护性,我不想 运行 python 修改 LD_LIBRARY_PATH 到 运行 这个脚本,但我可以不知道为什么它没有选择动态链接器显然知道的库。我错过了什么?

原来我的/usr/lib里藏着一个旧的libpixman.so(它是libcairo的依赖),而libcairo安装的文件夹里藏着一个更新的libpixman。因此,当 LD_LIBRARY_PATH 设置为 libcairo 的位置时,它会选择有效的新 libpixman,而当它未设置时,它会选择旧的。从 /usr/lib 中删除旧的 libpixman 修复了所有问题。