[轉]swoole安裝報錯詳解 mysqlnd_find_charset_nr in Unknow


今天通過pecl安裝 swoole

pecl install swoole
步驟很簡單,但是最后安裝成功后發現phpinfo()中未顯示swoole擴展,執行:

php -m | grep 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過程中,如果有其它報錯,也可以參考Github上關於swoole的issue,附上鏈接:

Swoole安裝問題,及websocket示例問題總結
---------------------
作者:GallopYD
來源:CSDN
原文:https://blog.csdn.net/qq292913477/article/details/81985824
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM