ホームページ >バックエンド開発 >PHPチュートリアル >xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-07-12 09:06:161351ブラウズ

xdebug を使用して thinkphp フレームワークの関数呼び出しグラフを分析します

開発中にパフォーマンスのチューニングが必要です。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 ポート

xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

各関数呼び出しを明確に確認できます:

xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

最も深刻な問題は実行にあり、実際には大量の SQL クエリが実行されます。 call は関数呼び出しの数です。

xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

多くの最適化方法があります。memcached を使用するか、thinkphp に付属のそれぞれのキャッシュを直接使用します。これは、呼び出しが少ないことは明らかです。

xdebug を使用して thinkphp フレームワーク関数呼び出しを分析するgraph_PHP チュートリアル

クエリキャッシュ
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 アプリケーションを分析して、遅いコードを見つけて診断し、高速化します

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/1065655.html技術記事 xdebug を使用して thinkphp フレームワーク関数呼び出しグラフを分析します。開発中に xdebug を使用して thinkphp フレームワーク関数呼び出しグラフを分析する必要があります。 xdebug のインストールについては、NetBeans の設定 Xd...
の 2 つの記事を参照してください。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。