PHP Warning: PHP Startup: Unable to load dynamic library 'swoole.so' mysqlnd_find_charset_nr

今天通過pecl安裝 swoole

pecl install swoole

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

php --ri| 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 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章