我怎么能告诉python使用哪个版本的libmysqlclient.so?

时间:2009-02-04 11:48:54

标签: python

我在共享托管服务器上运行python脚本,直到今天早上有MySQL版本4.现在它有版本5.我的python脚本无法再连接到MySQL,因为它找不到libmysqlclient_r.so。 14:

$ python my_script.py
Traceback (most recent call last):
File "my_script.py", line 6, in ?
import MySQLdb
 File "/home/lib/python2.4/site-packages/PIL-1.1.6-py2.4-linux-i686.egg/__init__.py", line 19, in ?

 File "build/bdist.linux-i686/egg/_mysql.py", line 7, in ?
 File "build/bdist.linux-i686/egg/_mysql.py", line 6, in __bootstrap__
ImportError: libmysqlclient_r.so.14: cannot open shared object file: No such file or directory

/ usr / lib中有各种其他版本的libmysqlclient:

/usr/lib/libmysqlclient.so.15
/usr/lib/libmysqlclient.so.14
/usr/lib/mysql/libmysqlclient.la
/usr/lib/mysql/libmysqlclient.so
/usr/lib/mysql/libmysqlclient_r.so
/usr/lib/mysql/libmysqlclient_r.a
/usr/lib/mysql/libmysqlclient_r.la
/usr/lib/mysql/libmysqlclient.a
/usr/lib/libmysqlclient.so
/usr/lib/libmysqlclient_r.so
/usr/lib/libmysqlclient_r.so.15
/usr/lib/libmysqlclient_r.so.15.0.0
/usr/lib/libmysqlclient.so.15.0.0

所以我的问题是:如何告诉python(版本2.4.3)使用哪个版本的libmysqlclient?

3 个答案:

答案 0 :(得分:5)

您无法告诉动态链接器使用哪个版本的库,因为SONAME(库+接口的全名)是二进制文件的一部分。

在您的情况下,您可以尝试将libmysqlclient_r.so.14上传到主机并相应地设置LD_LIBRARY_PATH,因此告诉动态链接器在解析共享对象时还要在系统目录中搜索哪些目录。

您可以使用ldd查看LD_LIBRARY_PATH是否有效:

$ ldd $path_to/_mysql.so
...
libmysqlclient_r.so.14 => $path_to_lib/libmysqlclient_r.so.14
...

否则,将显示有关未解析的共享对象的错误消息。

当然,在重建MySQLdb以使用新库之前,这只能是一个临时修复。

答案 1 :(得分:1)

您必须重新编译python-mysql(又名MySQLdb)才能将其链接到新版本的libmysqlclient。

如果您的主机最初设置了环境而不是编译它,那么您将不得不纠缠它们。

  

/usr/lib/libmysqlclient.so.14

这看起来像是旧的libmysqlclient的残余,应该被删除。 _r和.a(静态)版本已经消失了,你真的不希望混合使用库,只会让设备混乱。

虽然你可以创建一个从libmysqlclient_r.so.14到.15的符号链接,但只有当新版本的客户端碰巧拥有你想要的功能的ABI时才能工作使用旧的 - 这是不太可能的,因为这是更改版本号的重点。

答案 2 :(得分:0)

一种解决方案是将您的PYTHONPATH环境变量设置为具有一些本地目录,并复制(或链接,我想)您想要的mysql库的版本。