ホームページ >バックエンド開発 >PHPチュートリアル >PHPインクルードクラスファイルのタイムアウト

PHPインクルードクラスファイルのタイムアウト

WBOY
WBOYオリジナル
2016-06-23 13:40:47863ブラウズ

最近、クラス関数の自動ロードを実行すると PHP が常にタイムアウトになることに気付きました。PHP のスロー クエリ ログを追跡すると、プログラムが特定のクラス ファイルをインクルードする際にスタックし、実際にタイムアウトになっていることがわかりました。

当初の位置付けは、IO 応答がタイムアウトし、ハードディスクの読み取りに問題があったということです。

いくつかのコマンドを使用して見つけます:

iostat -d -x -k 1 10 // 10 回実行して、iostat の wait パラメーターが非常に大きく、通常は await の 2 つのパラメーターが近いほど大きいことを確認します。 svctm が優れているほど、IO パフォーマンスが向上します。博的他のブログを参照してください。

await:  每一个IO请求的处理的平均时间(单位是微秒毫秒)。这里可以理解为IO的响应时间,一般地系统IO响应时间应该低于5ms,如果大于10ms就比较大了。         这个时间包括了队列时间和服务时间,也就是说,一般情况下,await大于svctm,它们的差值越小,则说明队列时间越短,反之差值越大,队列时间越长,说明系统出了问题。svctm    表示平均每次设备I/O操作的服务时间(以毫秒为单位)。如果svctm的值与await很接近,表示几乎没有I/O等待,磁盘性能很好,如果await的值远高于svctm的值,则表示I/O队列等待太长,         系统上运行的应用程序将变慢。

Sudo IOTOP -O, // ハードディスクのスクラッチ手順を表示し、プロセス IO 占有率を確認します

Sudo Perf Top // プロセス IO 占有率を確認します

Sudo HDPARM -T / dev/ **** ディスク読み取り効率の表示

表示: バッファリングされたディスク読み取りのタイミング: 3.14 秒で 10 MB = 3.18 MB/秒

中断不可のスリープを表示

while do date; $8=="D") print $0;}'; 完了

さらなる原因はまだ不明です。ハードディスクに不良セクタがある可能性があります。


追記:

http://my.oschina.net/leejun2005/blog?disp=2&catalog=186193



声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。