我正在尝试让 phpmyadmin 与 mysql(mariadb fork)一起工作。
当我尝试访问 phpmyadmin 时,浏览器中收到以下错误消息:
> phpMyAdmin - Error The mysqli extension is missing. Please check your
> PHP configuration. <a href="Documentation.html#faqmysql"
> target="documentation"><img src="themes/dot.gif" title="Documentation"
> alt="Documentation" class="icon ic_b_help" /></a>
因此我在 /etc/php.ini 中添加了以下行:
extension=/usr/lib64/php/modules/mysqli.so
现在,当我启动 apache 时,我在 php_errors.log 中收到以下错误:
[12-Feb-2013 00:09:44] PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/mysqli.so' - libmysqlclient.so.16: cannot open shared object file: No such file or directory in Unknown on line 0
以下是 mysqli.so 上的 ldd 命令的输出:
[ollie@localhost modules]$ ldd mysqli.so
linux-vdso.so.1 => (0x00007fffd29ff000)
libmysqlclient.so.16 => not found
libz.so.1 => /lib64/libz.so.1 (0x00007ffd84b10000)
libcrypt.so.1 => /lib64/libcrypt.so.1 (0x00007ffd848d9000)
libnsl.so.1 => /lib64/libnsl.so.1 (0x00007ffd846c0000)
libm.so.6 => /lib64/libm.so.6 (0x00007ffd8443b000)
libssl.so.10 => /usr/lib64/libssl.so.10 (0x00007ffd841e0000)
libcrypto.so.10 => /usr/lib64/libcrypto.so.10 (0x00007ffd83e46000)
libc.so.6 => /lib64/libc.so.6 (0x00007ffd83ab2000)
libfreebl3.so => /lib64/libfreebl3.so (0x00007ffd83850000)
libgssapi_krb5.so.2 => /lib64/libgssapi_krb5.so.2 (0x00007ffd8360e000)
libkrb5.so.3 => /lib64/libkrb5.so.3 (0x00007ffd8332e000)
libcom_err.so.2 => /lib64/libcom_err.so.2 (0x00007ffd8312a000)
libk5crypto.so.3 => /lib64/libk5crypto.so.3 (0x00007ffd82efe000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007ffd82cf9000)
/lib64/ld-linux-x86-64.so.2 (0x00007ffd84f5f000)
libkrb5support.so.0 => /lib64/libkrb5support.so.0 (0x00007ffd82aee000)
libkeyutils.so.1 => /lib64/libkeyutils.so.1 (0x00007ffd828eb000)
libresolv.so.2 => /lib64/libresolv.so.2 (0x00007ffd826d0000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007ffd824b3000)
libselinux.so.1 => /lib64/libselinux.so.1 (0x00007ffd82293000)
我确认 libmysqlclient.so.16 位于 /usr/lib 下。我尝试将 /usr/lib 添加到我的 LD_LIBRARY_PATH 环境变量中,但没有效果。
以下是有关我的环境的更多详细信息:
CentOS:6.3
PHP:5.3.3
DB 版本:
mysql Ver 15.1 Distrib 5.5.29-MariaDB,适用于 Linux (x86_64),使用 readline 5.1
答案1
您还需要安装MariaDB-compat
RPM 以提供与针对较低版本的 MySQL 构建的系统包的兼容性。当前文件名是,MariaDB-5.5.29-centos6-x86_64-compat.rpm
您可以在任何镜像站点找到它。
如果此方法无法解决问题,向 MariaDB 报告错误。
答案2
所以问题可能就在这里。
extension=/usr/lib64/php/modules/mysqli.so
您正在使用 mysqli php 包的 64 位版本,但您在 /usr/lib 中找到的 libmysqlclient.so.16 可能是 32 位版本
运行以下命令
file /usr/lib/libmysqlclient.so.16
现在这可能是一个符号链接,因此只需继续跟踪它直到找到文件并确保它是 64 位版本。