ホームページ >バックエンド開発 >PHPチュートリアル >xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル
開発中にパフォーマンスのチューニングが必要です。xdebug を使用して、thinkphp フレームワークの関数呼び出しグラフを分析します。
xdebugのインストールについては、これらの2つの記事を参照してください
NetBeans は PHP をリモートでデバッグするように Xdebug を構成します
php拡張機能xdebugのインストールとkcachegrindによるシステム分析
1.xdebugをインストールします
最初に http://www.xdebug.org にアクセスしていくつかのドキュメントを読む必要があります。xdebug は php 拡張機能としてインストールされます
。# http://www.xdebug.org/files/xdebug-2.3.3.tgz
# tar -xzf xdebug-2.3.3.tgz
# cd xdebug-2.3.3
# /usr/local/php/bin/phpize
# ./configure --enable-xdebug --with-php-config=/usr/local/php/bin/php-config
# 作成&&作成インストール
2.許可を与える
# mkdir -p /tmp/xdebug
#chmod 755 /tmp/xdebug
# chown nothing:nobody /tmp/xdebug
3. PHP 設定を変更します
php.iniファイルを変更する
[Xデバッグ]
zend_extension=xdebug.so
xdebug.profiler_enable=on
xdebug.trace_output_dir=/tmp/xdebug
xdebug.profiler_output_dir=/tmp/xdebug
4. php-fpmを再起動します
#killallphp-fpm
# /etc/init.d/php-fpm
5. PHP を実行してログを生成します
設定後、php ファイルを実行すると、/tmp/xdebug に次のようなログ ファイルが生成されます
-rw-r--r-- 1 誰も誰も 4615252 10 月 27 日 17:31 cachegrind.out.29293
6. kcachegrind を使用してログをグラフィカルに分析します
kcachegrind の Windows ポート
各関数呼び出しを明確に確認できます:
最も深刻な問題は実行にあり、実際には大量の SQL クエリが実行されます。 call は関数呼び出しの数です。
多くの最適化方法があります。memcached を使用するか、thinkphp に付属のそれぞれのキャッシュを直接使用します。これは、呼び出しが少ないことは明らかです。
クエリキャッシュ
http://document.thinkphp.cn/manual_3_2.html#query_cache
高い適時性を必要としないデータ クエリの場合は、クエリ キャッシュ機能を使用してパフォーマンスを向上させることができ、キャッシュや取得のために独自にキャッシュ メソッドを使用する必要はありません。
クエリキャッシュ機能はすべてのデータベースをサポートし、すべてのキャッシュ方法と有効期間をサポートします。
クエリ キャッシュを使用する場合は、Model クラスのキャッシュ メソッドを呼び出すだけです。例:
1.$Model->cache(true)->where('status=1')->select();
SQL解析キャッシュ
http://document.thinkphp.cn/manual_3_2.html#sql_build_cache
クエリ キャッシュに加えて、ThinkPHP は SQL 解析キャッシュもサポートしています。ThinkPHP の ORM メカニズムにより、すべての SQL が動的に生成され、データベース ドライバーによって実行されます。
そのため、アプリケーションに多数の SQL クエリ要件がある場合は、SQL 解析キャッシュをオンにして SQL 解析を減らし、パフォーマンスを向上させることができます。 SQL 解析キャッシュを有効にするには、次のように設定するだけです:
1.'DB_SQL_BUILD_CACHE' => true、
データベース クエリの SQL 作成キャッシュをオンにすることができます。デフォルトのキャッシュ モードは、xcache および apc モード キャッシュもサポートします。
を設定するだけです。
1.'DB_SQL_BUILD_QUEUE' => 'xcache',
プロジェクトの SQL クエリの量が非常に膨大になる可能性があることがわかっているため、たとえば、SQL 解析キャッシュが 20 レコードを超えないようにする場合は、次のように設定できます。
1.'DB_SQL_BUILD_LENGTH' => 20, // SQL キャッシュのキューの長さ。
プロファイラーはどのように嘘をつくか: gprof と KCachegrind のケース
PHP アプリケーションをスピードアップ、スピードアップ、スピードアップ! , パート 2: PHP アプリケーションを分析して、遅いコードを見つけて診断し、高速化します
の 2 つの記事を参照してください。