php5.4 と php-redis 間の競合の解決策を記録します
最近、ubuntu ソースの更新により、元の新しいソースがローカル システム ライブラリの一部のライブラリと競合し、システム デスクトップがその後、php5.4.9、redis、php-redis拡張機能、php-redis拡張機能2,10もインストールし直しました。しかし、元のプロジェクトを公開するとすぐに、nginx 502 エラーが報告されました (nginx 502 エラーは本当に頭の痛い問題です)。 nginx ログを開いて表示します
[エラー] 29229#0: *1403 recv() が失敗しました (104: ピアによる接続リセット) アップストリームからの応答ヘッダーの読み取り中に、クライアント: 127.0.0.1、サーバー:
何を言っているのかわかりません。その後、php-fpm エラー ログを開いてログを取得しました
[08-Oct-2013 21:22:23] 警告: [プール www] 子 12026 は開始から 5.997917 秒後にシグナル 11 (SIGSEGV - コア ダンプ) で終了しました
[08-Oct-2013 21:22:23] 通知: [プール www] 子 12034 が開始されました
確かなことの 1 つは、php-fpm が特定の時点の後にプロセスを再起動したということです。まだ手がかりがありません。インターネットでいろいろ検索したところ、便利な追跡方法を見つけました。
1. php-fpm をセットアップし、ワークプロセスを 1 つだけ開始します
2. php-fpm を再起動し、ps aux| grep php-fpm を実行してワークプロセス番号 pid を取得します
3. strace -p pid
私が得た情報は次のとおりです
getcwd("/home/www/wms2.xxxx.com", 4096) = 26
lstat("/home/www/wms2.xiaomi.com/./RWebUser.php", 0x7ffff4e30a10) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xiaomi.com/protected/vendor/wms/api/RWebUser.php", 0x7ffff4e30a10) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xiaomi.com/protected/vendor/wms/RWebUser.php", 0x7ffff4e30a10) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xiaomi.com/protected/extensions/log/RWebUser.php", 0x7ffff4e30a10) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xiaomi.com/protected/modules/rights/components/RWebUser.php", {st_mode=S_IFREG|0777, st_size=2945, ...}) = 0
lstat("/home/www/wms2.xiaomi.com/protected/modules/rights/components", {st_mode=S_IFDIR|0777, st_size=4096, ...}) = 0
lstat("/home/www/wms2.xiaomi.com/protected/modules/rights", {st_mode=S_IFDIR|0777, st_size=4096, ...}) = 0
lstat("/home/www/wms2.xiaomi.com/protected/modules", {st_mode=S_IFDIR|0777, st_size=4096, ...}) = 0
open("/home/www/wms2.xiaomi.com/protected/modules/rights/components/RWebUser.php", O_RDONLY) = 5
fstat(5, {st_mode=S_IFREG|0777, st_size=2945, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2945, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2945, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2945, ...}) = 0
mmap(NULL, 2945, PROT_READ, MAP_SHARED, 5, 0) = 0x7fd9b4804000
mmap(NULL, 266240, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd9b442f000
ムンマップ(0x7fd9b4804000, 2945) = 0
閉じる(5) = 0
getcwd("/home/www/wms2.xxx.com", 4096) = 26
lstat("/home/www/wms2.xxx.com/./XMCCacheHttpSession.php", 0x7ffff4e31060) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xxx.com/protected/vendor/wms/api/XMCCacheHttpSession.php", 0x7ffff4e31060) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xxx.com/protected/vendor/wms/XMCCacheHttpSession.php", 0x7ffff4e31060) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xxx.com/protected/extensions/log/XMCCacheHttpSession.php", 0x7ffff4e31060) = -1 ENOENT (そのようなファイルまたはディレクトリはありません)
lstat("/home/www/wms2.xxx.com/protected/modules/rights/components/XMCCacheHttpSession.php", 0x7ffff4e31060) = -1 ENOENT (そのようなファイルやディレクトリはありません)
lstat("/home/www/wms2.xxx.com/protected/modules/rights/XMCCacheHttpSession.php", 0x7ffff4e31060) = -1 ENOENT (そのような ファイル または ディレクトリはありません)
lstat("/home/www/wms2.xxx.com/protected/components/XMCCacheHttpSession.php", {st_mode=S_IFREG|0777, st_size=2612, ...}) = 0
open("/home/www/wms2.xxx.com/protected/components/XMCCacheHttpSession.php", O_RDONLY) = 5
fstat(5, {st_mode=S_IFREG|0777, st_size=2612, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2612, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2612, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2612, ...}) = 0
mmap(NULL, 2612, PROT_READ, MAP_SHARED, 5, 0) = 0x7fd9b4804000
munmap(0x7fd9b4804000, 2612) = 0
閉じる(5) = 0
sendto(4, "get 6cacd9674ad21aa083b5032b1a29"..., 39, MSG_DONTWAIT|MSG_NOSIGNAL, NULL, 0) = 39
recvfrom(4, 0x2806d88, 8196, 64, 0, 0) = -1 EAGAIN (リソースが一時的に利用不可)
poll([{fd=4, events=POLLIN}], 1, 5000) = 1 ([{fd=4, reevents=POLLIN}])
recvfrom(4, "VALUE 6cacd9674ad21aa083b5032b1a"..., 8196, MSG_DONTWAIT, NULL, NULL) = 128
lstat("/home/www/wms2.xxx.com/yii/web/CHttpCookie.php", {st_mode=S_IFREG|0777, st_size=2772, ...}) = 0
lstat("/home/www/wms2.xxx.com/yii/web", {st_mode=S_IFDIR|0777, st_size=4096, ...}) = 0
open("/home/www/wms2.xxx.com/yii/web/CHttpCookie.php", O_RDONLY) = 5
fstat(5, {st_mode=S_IFREG|0777, st_size=2772, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2772, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2772, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2772, ...}) = 0
mmap(NULL, 2772, PROT_READ, MAP_SHARED, 5, 0) = 0x7fd9b4804000
munmap(0x7fd9b4804000, 2772) = 0
閉じる(5) = 0
stat("/home/www/wms2.xxx.com/protected/extensions/redis/XMRedis.php", {st_mode=S_IFREG|0777, st_size=2672, ...}) = 0
lstat("/home/www/wms2.xxx.com/protected/extensions/redis/XMRedis.php", {st_mode=S_IFREG|0777, st_size=2672, ...}) = 0
lstat("/home/www/wms2.xxx.com/protected/extensions/redis", {st_mode=S_IFDIR|0777, st_size=4096, ...}) = 0
lstat("/home/www/wms2.xxx.com/protected/extensions", {st_mode=S_IFDIR|0777, st_size=4096, ...}) = 0
open("/home/www/wms2.xxx.com/protected/extensions/redis/XMRedis.php", O_RDONLY) = 5
fstat(5, {st_mode=S_IFREG|0777, st_size=2672, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2672, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2672, ...}) = 0
fstat(5, {st_mode=S_IFREG|0777, st_size=2672, ...}) = 0
mmap(NULL, 2672, PROT_READ, MAP_SHARED, 5, 0) = 0x7fd9b4804000
munmap(0x7fd9b4804000, 2672) = 0
閉じる(5) = 0
ソケット(PF_INET6, SOCK_DGRAM, IPPROTO_IP) = 5
閉じる(5) = 0
ソケット(PF_INET、SOCK_STREAM、IPPROTO_IP) = 5
fcntl(5, F_GETFL) = 0x2 (フラグ O_RDWR)
fcntl(5, F_SETFL, O_RDWR|O_NONBLOCK) = 0
connect(5, {sa_family=AF_INET, sin_port=htons(22122), sin_addr=inet_addr("10.237.36.231")}, 16) = -1 EINPROGRESS (操作は進行中です)
poll([{fd=5, events=POLLIN|POLLOUT|POLLERR|POLLHUP}], 1, 3000) = 1 ([{fd=5, revents=POLLOUT}])
getsockopt(5, SOL_SOCKET, SO_ERROR, [0], [4]) = 0
fcntl(5, F_SETFL, O_RDWR) = 0
setsockopt(5, SOL_TCP, TCP_NODELAY, [1], 4) = 0
poll([{fd=5, events=POLLIN|POLLPRI|POLLERR|POLLHUP}], 1, 0) = 0 (タイムアウト)
sendto(5, "*2rn$4rnAUTHrn$9rnxm_wms_rsrn", 29, MSG_DONTWAIT, NULL, 0) = 29
poll([{fd=5, events=POLLIN|POLLPRI|POLLERR|POLLHUP}], 1, 0) = 0 (タイムアウト)
poll([{fd=5, events=POLLIN|POLLERR|POLLHUP}], 1, 3000) = 1 ([{fd=5, revents=POLLIN}])
recvfrom(5, "+OKrn", 8192, MSG_DONTWAIT, NULL, NULL) = 5
--- SIGSEGV (セグメンテーション エラー) @ 0 (0) ---
プロセス 6011 が切り離されました
確認できるように、XMRedis の実行後にプロシージャ 6011 が終了するのは php-redis の問題です。
继续追查最終终発行现了有段代网问题
試してみましょう{
$this->_redis->pconnect($this->host, $this->port, $this->timeout);
// クライアント オプションを設定します。 接続後に必要です
//var_dump(Redis::OPT_SERIALIZER,Redis::SERIALIZER_PHP);exit();
$this->_redis->setOption(Redis::OPT_SERIALIZER,Redis::SERIALIZER_PHP);
//$this->_redis->setOption(0, 0);
$this->_redis->auth("xm_wms_rs");
throw new CHttpException(500, 「Redis occurs an error:」 . $e->getMessage());
}
}
色のコードを使用する段階では 502 エラーが発生しますが、色のコードを使用する場合は問題ありません。
setOption これは神马东西呢?查了下php-redis api
$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_NONE); // don't
$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP); // use built-in serialize/unserialize 用php内置の順序化
$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_IGBINARY); // use igBinary serialize/unserialize 用扩展IGBINARY序列化
$redis->setOption(Redis::OPT_PREFIX, 'myAppName:'); // use custom prefix on all keys redis key前缀
$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP); 用此就报502
PHP の組み込みシリアル化を使用すると問題が発生するのはなぜですか?どうしたの?
その後、IGBINARY 拡張機能をインストールしましたが、まだ動作しませんでした。最後に、php-redis の最新バージョン 2.24 をインストールして再度実行しましたが、まったく問題ありませんでした。
2.24 バージョン php-redis ソース コード アドレス https://github.com/nicolasff/phpredis