目次
mongo服务器的配置
ホームページ バックエンド開発 PHP7 xhprof を使用して php7 で php のパフォーマンスをテストするにはどうすればよいですか? (手法の紹介)

xhprof を使用して php7 で php のパフォーマンスをテストするにはどうすればよいですか? (手法の紹介)

Jul 15, 2020 pm 05:11 PM
php7 PHPのパフォーマンス

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で解析して表示し、表示形式には棒グラフ、ウォーターフォールフロー、フレームチャートなどがあります。

    アプリケーション
  • 次に、
Intrusive

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(&#39;His&#39;, time()) . ".material.xhprof",
  //     serialize($data)
  // );
ログイン後にコピー

ここで生成された .xhprof ファイルは tmp ディレクトリにあります。デフォルトの UI では、次の場所でも .xhprof が検索されます。ファイル

データを検索するために使用されるデフォルトの UI をインストールします

git clone git@github.com:phacility/xhprof.git
ログイン後にコピー

xhprof_lib

および

このリポジトリ xhprof_html ディレクトリを Web フォルダーに移動し、xhprof_html/index.php に移動してトレース リストを表示します。

関数呼び出しのメモを表示したい場合は、Callgraph をインストールする必要があります

Callgraph のインストール

Callgraph は実際には3つのツールの組み合わせになります。

1 つは C の関数呼び出しツリーを生成するために使用される cflow または calltree で、以下では cflow を中心に紹介します。

graphviz によって強化された、ドット テキスト グラフィックス言語を処理するためのツール。 C 関数呼び出しツリーをドット形式に変換するためのスクリプト:tree2dotx

Ubuntu を例として、それらを個別にインストールします:

sudo apt-get install cflow graphviz
ログイン後にコピー

次に、tree2dotx と Callgraph をインストールします。デフォルトでは /usr/local/bin にインストールされます。

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}
ログイン後にコピー

次の 2 つのレンダリングが表示されます:

侵入的:

# 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";  #这里依据个人目录而配
}
ログイン後にコピー
これが意味するのは、非侵入的な検出パフォーマンスの目的を達成するために、プロジェクトの PHP コードを実行する前に header.php を実行することです

xhgui 設定 (頻度ログ生成の数)xhgui の config/config.default.php で、サンプリング ヒット数を設定できます;

return rand(1, 100) === 42; 为1%的采样率,改成return True;则标识每次都采样

&#39;profiler.enable&#39; => 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 サイトの他の関連記事を参照してください。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

php7がTCPポートが機能していないことを検出した場合の問題を解決する方法 php7がTCPポートが機能していないことを検出した場合の問題を解決する方法 Mar 22, 2023 am 09:30 AM

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

php7.0にmongo拡張機能をインストールする方法 php7.0にmongo拡張機能をインストールする方法 Nov 21, 2022 am 10:25 AM

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

php7.0 にプラグインがインストールされているのに、まだインストールされていないと表示される場合はどうすればよいですか? php7.0 にプラグインがインストールされているのに、まだインストールされていないと表示される場合はどうすればよいですか? Apr 02, 2024 pm 07:39 PM

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

PHP を使用してパフォーマンス分析とチューニングを行う方法 PHP を使用してパフォーマンス分析とチューニングを行う方法 Jun 06, 2023 pm 01:21 PM

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

php7.0のインストールとデプロイ方法 php7.0のインストールとデプロイ方法 Nov 30, 2022 am 09:56 AM

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

PHP サーバー環境 FAQ ガイド: 一般的な問題を迅速に解決する PHP サーバー環境 FAQ ガイド: 一般的な問題を迅速に解決する Apr 09, 2024 pm 01:33 PM

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

php8 と php7 ではどちらが優れていますか? php8 と php7 ではどちらが優れていますか? Nov 16, 2023 pm 03:09 PM

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

システムの再起動後にUnixSocketの権限を自動的に設定する方法は? システムの再起動後にUnixSocketの権限を自動的に設定する方法は? Mar 31, 2025 pm 11:54 PM

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

See all articles