
Ubuntu 17.10 で実行するとphp -v
、エラー メッセージが表示されます。
$ php -v
PHP Warning: PHP Startup: Unable to load dynamic library
'/usr/lib/php/20160303/zmq.so' - /usr/lib/php/20160303/zmq.so:
undefined symbol: _zval_get_string_func in Unknown on line 0
PHP 5.6.33-1+ubuntu17.10.1+deb.sury.org+1 (cli)
Copyright (c) 1997-2016 The PHP Group
Zend Engine v2.6.0, Copyright (c) 1998-2016 Zend Technologies
with Zend OPcache v7.0.6-dev, Copyright (c) 1999-2016, by Zend
Technologies
with Xdebug v2.5.5, Copyright (c) 2002-2017, by Derick Rethans
locate zmq.so
次のような結果が得られます。
$ locate zmq.so
/usr/lib/php/20160303/zmq.so
/usr/lib/x86_64-linux-gnu/libzmq.so
/usr/lib/x86_64-linux-gnu/libzmq.so.5
/usr/lib/x86_64-linux-gnu/libzmq.so.5.1.2
zmq.so
正しいディレクトリにあるのに、なぜそのエラー メッセージが表示され続けるのでしょうか?
答え1
これはzmq.so
PECL拡張からのものであるジミーおっしゃるとおり、そこにありますが、読み込まれていません。最近 PHP バージョンを更新した場合、これが問題の原因である可能性があります (ディストリビューションのアップグレードによっても発生する可能性があります)。
いずれにしても、次のコマンドを使用して拡張機能を再構築してみるのが最善策だと思います。
git clone git://github.com/mkoppanen/php-zmq.git
cd php-zmq
phpize && ./configure
make
sudo make install
# now we tell php to use this extension
echo "extension=zmq.so" >> /etc/php/{version_number}/mods-available/zmq.ini
sudo phpenmod zmq
sudo service apache2 restart #Since you also tagged this with apache2
この情報は、次のリンクから見つけました。