PERL+mysql: неопределенный символ: mysql_init
Я обновил mysql (клиент + сервер +dev) из rpms, доступных на mysql.com.
rpm -i MySQL-server-5.5.14-1.linux2.6.x86_64.rpm
rpm -i MySQL-client-5.5.14-1.linux2.6.x86_64.rpm
rpm -i MySQL-devel-5.5.14-1.linux2.6.x86_64.rpm
Теперь скрипт, который используется для подключения к другому серверу, говорит:
perl: symbol lookup error: /usr/lib64/perl5/site_perl/5.8.8/x86_64-linux-thread-multi/auto/DBD/mysql/mysql.so: undefined symbol: mysql_init
сценарий:
use DBI;
$dsn="db";
$host="my.host.ip";
$user="anonymous";
$password="";
# Connect to the database.
$dbh= DBI->connect("DBI:mysql:host=$host;database=$dsn",$user, $password,{'RaiseError' => 1});
Итак, я переустановил DBI-1.616 и DBD-mysql-4.019 из источников. для DBD-mysql, Make test говорит:
$ make test
PERL_DL_NONLAZY=1 /usr/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(0, 'blib/lib', 'blib/arch')" t/*.t
t/00base....................ok 1/6
# Failed test 'use DBD::mysql;'
# in t/00base.t at line 21.
# Tried to use 'DBD::mysql'.
# Error: Can't load '/usr/local/package/DBD-mysql-4.019/blib/arch/auto/DBD/mysql/mysql.so' for module DBD::mysql: /usr/local/package/DBD-mysql-4.019/blib/arch/auto/DBD/mysql/mysql.so: undefined symbol: mysql_get_server_version at /usr/lib64/perl5/5.8.8/x86_64-linux-thread-multi/DynaLoader.pm line 230.
# at (eval 6) line 2
# Compilation failed in require at (eval 6) line 2.
# BEGIN failed--compilation aborted at t/00base.t line 21.
t/00base....................NOK 2FAILED--Further testing stopped: Unable to load DBD::mysql
make: *** [test_dynamic] Error 9
Как я могу решить эту проблему?
Спасибо!
2 ответа
ОК, у меня есть решение Насколько я понимаю, дистрибутив mysql, который я использовал, статически связан. Поэтому, когда DB:mysql установлен, его необходимо скомпилировать с помощью следующих статических библиотек:
mkdir /tmp/mysql-static
cp /usr/lib64/mysql/*.a /tmp/mysql-static
perl Makefile.PL --libs="-L/tmp/mysql-static -lmysqlclient"
make
make test
make install
rm -rf /tmp/mysql-static
Тот факт, что DBD-MySQL теперь не может найти символ mysql_get_server_version
предполагает, что в новой установленной клиентской библиотеке MySQL, вероятно, отсутствует эта конкретная функция (или она была переименована, или что-то в этом роде). Учитывая, что вы не предоставляете информацию о том, что вы обновили или с чего-либо, трудно исследовать и дать вам полный ответ, врученный вам на планшете, но я был бы склонен попробовать обновление DBD-mysql на Исходя из того, что может быть задействовано не обратно совместимое изменение API, и более новая версия DBD-mysql могла бы справиться с этим лучше.