swoole安装报错详解 mysqlnd_find_charset_nr in Unknow

Posted phper12580

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了swoole安装报错详解 mysqlnd_find_charset_nr in Unknow相关的知识,希望对你有一定的参考价值。

 

今天安装 swoole扩展时候,最后一步报错如下:

php Warning: PHP Startup: Unable to load dynamic library ‘/usr/lib64/php/modules/swoole.so‘ - /usr/lib64/php/modules/swoole.so: undefined symbol: mysqlnd_find_charset_nr in Unknown on line 0

仔细看报错发现这条报错是由swoole.so报出来的,说明在加载swoole.so的时候报的找不到 mysqlnd_find_charset_nr ,这是一个以 mysqlnd 打头的一个关键字,而 mysqlnd 又是 PHP 的一个扩展,通过阅读 swoole/swoole.mysql.c 的源码我们发现有如下一段:

const MYSQLND_CHARSET* cset = mysqlnd_find_charset_nr(client->connector.character_set);

if (cset == NULL)
{

    swoole_php_fatal_error(E_ERROR, "unknown mysql charset[%s].", client->connector.character_set);

    RETURN_FALSE;

}

 


从上面的源码我们可以看出,原来 swoole 是需要依赖 msyqlnd 这个扩展的,我们发现 phpinfo() 里面 msyqlnd 扩展是存在的为什么还会报这个错呢。

 

  最后发现 PHP默认加载的扩展都在 /usr/lib64/php/modules/ 这个目录里在,这里面的 .so 文件是默认加载的,关于这些扩展的配置不是在 /etc/php.ini 中,而是在 /etc/php.d/ 这个目录中,这个目录当中的所有的 .ini 文件是在 /etc/php.ini 加载完成后再加载的,而我们的 extension=swoole.so 的配置是写在 /etc/php.ini 的文件末尾,所以是先加载了 swoole.so 然后再加载 mysqlnd.so,这就导致了 swoole 找不到 mysqlnd_find_charset_nr 。

 

解决方法:
1、将/etc/php.d/ 目录中的mysqlnd.ini文件删除

2、在 /etc/php.ini 的 extension=swoole.so 上面一行添加 extension=mysqlnd.so

3、重新启动 php-fpm 

这样可以解决问题了,同样可能还会遇到以下报错:

PHP Warning: PHP Startup: Unable to load dynamic library ‘/usr/lib64/php/modules/swoole.so‘ - /usr/lib64/php/modules/swoole.so: undefined symbol: php_sockets_le_socket in Unknown on line 0

 

解决的方法也是类似的:

1、将/etc/php.d/ 目录中的sockets.ini文件删除

2、在 /etc/php.ini 的 extension=swoole.so 上面一行添加 extension=sockets.so

3、重新启动 php-fpm 

 

以上是关于swoole安装报错详解 mysqlnd_find_charset_nr in Unknow的主要内容,如果未能解决你的问题,请参考以下文章

安装swoole报错:致命错误:curl/curl.h:没有那个文件或目录

php升级openssl扩展,swoole升级openssl扩展,linux安装openssl版本

安装swoole扩展

安装hiredis后swoole扩展消失

liunx执行pecl install swoole报错“failed to run `phpize‘”

liunx执行pecl install swoole报错“failed to run `phpize‘”