启动 apache 时 phpmyadmin 出现错误消息

启动 apache 时 phpmyadmin 出现错误消息

我正在尝试让 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-compatRPM 以提供与针对较低版本的 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 位版本。

相关内容