xhprof を使用して php7 で php のパフォーマンスをテストするにはどうすればよいですか? (手法の紹介)
#はじめに
1 背景
- PHP の xhprof 拡張機能 Facebook は、Facebook が HHVM を完全に使用し、PHP zend エンジンを使用しなくなったため、更新および保守されなくなります。
- xhprof は、新しいバージョンの PHP (PHP7) をサポートしていません。Tideways 拡張機能は、xhprof プロジェクト フォークから維持されており、現在、PHP 7.2、7.1、7.0、5.6、および 5.5 をサポートしています。
- tideways はオープンソース プロジェクトです。課金されるのは UI サービスのみです。実際、xhgui は私たちの日常のニーズを完全に満たすことができます。
2 Function
Tideways は、PHP のパフォーマンスをテストするために使用される拡張機能で、PHP の実行プロセス全体で呼び出される関数、関数呼び出し数、実行時間、 CPU 時間、メモリ使用量、メモリ ピーク、合計実行時間、合計 CPU 時間、合計メモリ使用量、合計メモリ ピークおよびその他のデータ、上記のデータを分析して PHP のパフォーマンスのボトルネックを特定、PHP 実行プロセスの分析など。3 利点
- tideways は、xhgui と組み合わされた PHP 拡張機能であるため、埋め込む必要はありません。 PHP コード モニタリング コード
- リクエストごとに実行ログを生成せずに実行頻度 (たとえば、1/100) を設定すると、パフォーマンスが低下します。また、実行頻度をアクティブに制御することもできます。制御するパラメータをリクエストすることで実行ログを生成します (debug=1)
- データを変換するためのシンプルで直接的な UI があります
- 次のことができます特定のインターフェースを分析したり、一定期間のインターフェースのリクエスト状況を分析したりするなど、データのフィルタリングの条件を自由に合わせることができます。 ## 非侵入的ではありますが、インターフェイスごとに実行ログが生成される場合、CPU とメモリの消費は無視できません。
5 実装原則
tideways 拡張機能は実行ログの生成を担当しますnginx では、fastcgi_param を設定することで実行されます。 PHP_VALUE auto_prepend_file, auto_prepend_fileで設定されたPHPファイルをリクエスト開始前に実行します ファイル内ではregister_shutdown_functionメソッドが使用されます PHPプロセスの最後に、潮汐路の埋め込みを実現するためにtideways_disableが呼び出され、実行ログがmongodbに保存されますmysqlやファイルをxhguiで解析して表示し、表示形式には棒グラフ、ウォーターフォールフロー、フレームチャートなどがあります。
- アプリケーション
- 次に、
と Non- の 2 つのアプリケーション方法を紹介します。侵入型 侵入型はコードにコードを追加することを指し、侵入型はデフォルトの UI を使用します。
非侵入型は、何も変更せずにコードを追加することを指します。 xhgui を非侵襲的に使用して、nginx/Apache を変更してコード インジェクションを実装します。インストールtideways_xhprof
git clone "https://github.com/tideways/php-xhprof-extension.git" cd php-xhprof-extension phpize ./configure --with-php-config=/usr/local/php7/bin/php-config make sudo make install
php.ini に extension=tideways_xhprof.so# を追加します。
##非侵入型:
<?php tideways_xhprof_enable(); // your application code $data = tideways_xhprof_disable(); file_put_contents( sys_get_temp_dir() . "/" . uniqid() . ".yourapp.xhprof", serialize($data) ); // $data = tideways_xhprof_disable(); // file_put_contents( // sys_get_temp_dir() . "/" . date('His', time()) . ".material.xhprof", // serialize($data) // );
データを検索するために使用されるデフォルトの UI をインストールします
git clone git@github.com:phacility/xhprof.git
xhprof_lib
およびこのリポジトリ xhprof_html ディレクトリを Web フォルダーに移動し、xhprof_html/index.php に移動してトレース リストを表示します。
関数呼び出しのメモを表示したい場合は、Callgraph をインストールする必要がありますCallgraph のインストール
graphviz によって強化された、ドット テキスト グラフィックス言語を処理するためのツール。 C 関数呼び出しツリーをドット形式に変換するためのスクリプト:tree2dotx
Ubuntu を例として、それらを個別にインストールします:sudo apt-get install cflow graphviz
wget -c https://github.com/tinyclub/linux-0.11-lab/raw/master/tools/tree2dotx wget -c https://github.com/tinyclub/linux-0.11-lab/raw/master/tools/callgraph sudo cp tree2dotx callgraph /usr/local/bin sudo chmod +x /usr/local/bin/{tree2dotx,callgraph}
侵入的:
# xhgui の侵入的な使用には mongodb が必要です
xhgui のインストールgit clone git@github.com:perftools/xhgui.git
Nginx の構成
server {
listen 80;
server_name site.localhost;
root /Users/markstory/Sites/awesome-thing/app/webroot/;
fastcgi_param PHP_VALUE "auto_prepend_file=/home/www/xhgui/external/header.php"; #这里依据个人目录而配
}
xhgui 設定 (頻度ログ生成の数)xhgui の config/config.default.php で、サンプリング ヒット数を設定できます;
return rand(1, 100) === 42; 为1%的采样率,改成return True;则标识每次都采样
'profiler.enable' => function() { // url 中包含debug=1则百分百捕获 if(!empty($_GET['debug'])){ return True; }else{ // 1%采样 return rand(1, 100) === 42; } }
mongodb的配置
xhgui/config/config.default.php
// Can be either mongodb or file. /* 'save.handler' => 'file', 'save.handler.filename' => dirname(__DIR__) . '/cache/' . 'xhgui.data.' . microtime(true) . '_' . substr(md5($url), 0, 6), */ 'save.handler' => 'mongodb', // Needed for file save handler. Beware of file locking. You can adujst this file path // to reduce locking problems (eg uniqid, time ...) //'save.handler.filename' => __DIR__.'/../data/xhgui_'.date('Ymd').'.dat', 'db.host' => 'mongodb://127.0.0.1:27017', 'db.db' => 'xhprof',
mongo服务器的配置
mongo > use xhprof > db.results.ensureIndex( { 'meta.SERVER.REQUEST_TIME' : -1 } ) > db.results.ensureIndex( { 'profile.main().wt' : -1 } ) > db.results.ensureIndex( { 'profile.main().mu' : -1 } ) > db.results.ensureIndex( { 'profile.main().cpu' : -1 } ) > db.results.ensureIndex( { 'meta.url' : 1 } )
最后展示几张xhgui的效果图
相关学习推荐:PHP编程从入门到精通
以上がxhprof を使用して php7 で php のパフォーマンスをテストするにはどうすればよいですか? (手法の紹介)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック

php5 では、fsockopen() 関数を使用して TCP ポートを検出できます。この機能を使用して、ネットワーク接続を開き、ネットワーク通信を実行できます。ただし、php7 では、fsockopen() 関数でポートを開けない、サーバーに接続できないなどの問題が発生する可能性があります。この問題を解決するには、socket_create() 関数とsocket_connect() 関数を使用して TCP ポートを検出します。

php7.0 に mongo 拡張機能をインストールする方法: 1. mongodb ユーザー グループとユーザーを作成します; 2. mongodb ソース コード パッケージをダウンロードし、ソース コード パッケージを "/usr/local/src/" ディレクトリに配置します; 3. 「src/」ディレクトリに入ります; 4. ソースコードパッケージを解凍します; 5. mongodb ファイルディレクトリを作成します; 6. ファイルを「mongodb/」ディレクトリにコピーします; 7. mongodb 設定ファイルを作成して設定を変更します。

PHP 7.0 でインストールされているプラグインが表示されない問題を解決するには: プラグインの設定を確認し、プラグインを有効にします。 PHP を再起動して、構成の変更を適用します。プラグイン ファイルの権限をチェックして、それらが正しいことを確認します。不足している依存関係をインストールして、プラグインが適切に機能することを確認します。他のすべての手順が失敗した場合は、PHP を再構築します。他に考えられる原因としては、プラグインのバージョンに互換性がない、間違ったバージョンをロードしている、PHP 構成の問題などが挙げられます。

PHP は人気のあるサーバーサイド言語として、Web サイトの開発と運用において重要な役割を果たしています。ただし、PHP コードの量が増加し続け、アプリケーションが複雑になるにつれて、パフォーマンスのボトルネックが発生する可能性がますます高まっています。この問題を回避するには、パフォーマンスの分析とチューニングを実行する必要があります。この記事では、PHP を使用してパフォーマンス分析とチューニングを行い、アプリケーションにより効率的な実行環境を提供する方法を簡単に紹介します。 1. PHP パフォーマンス分析ツール 1.XdebugXdebug は、広く使用されているコード分析ツールです。

php7.0 をインストールおよび展開する方法: 1. PHP 公式 Web サイトにアクセスして、ローカル システムに対応するインストール バージョンをダウンロードします; 2. ダウンロードした zip ファイルを指定したディレクトリに解凍します; 3. コマンド ライン ウィンドウを開いて、次のリンクに移動します。 「E:\php7」ディレクトリ 「php -v」コマンドを実行するだけです。

PHP サーバー環境の一般的な解決策には、正しい PHP バージョンがインストールされていること、および関連ファイルがモジュール ディレクトリにコピーされていることを確認することが含まれます。 SELinux を一時的または永続的に無効にします。 PHP.ini をチェックして構成し、必要な拡張機能が追加され、正しく設定されていることを確認します。 PHP-FPM サービスを開始または再起動します。 DNS 設定に解決の問題がないか確認してください。

PHP7 と比較すると、PHP8 にはパフォーマンス、新機能と構文の改善、型システム、エラー処理と拡張機能の点でいくつかの利点と改善点があります。ただし、どのバージョンを使用するかは、特定のニーズとプロジェクトの状況によって異なります。詳細な紹介: 1. パフォーマンスの向上、PHP8 はコードの実行速度を向上できるジャストインタイム (JIT) コンパイラーを導入します; 2. 新機能と構文の改善、PHP8 は名前付きパラメーターとオプションのパラメーターの宣言をサポートします。関数の作成 呼び出しがより柔軟になり、匿名クラス、プロパティの型宣言などが導入されています。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...
