Rumah >pembangunan bahagian belakang >tutorial php >Cara cepat mendiagnosis isu prestasi PHP
Teknik berkesan untuk mendiagnosis isu prestasi PHP dengan cepat termasuk menggunakan Xdebug untuk mendapatkan data prestasi dan kemudian menganalisis output Cachegrind. Gunakan Blackfire untuk melihat jejak permintaan dan menjana laporan prestasi. Periksa pertanyaan pangkalan data untuk mengenal pasti pertanyaan yang tidak cekap. Menganalisis penggunaan memori, melihat peruntukan memori dan penggunaan puncak.
PHP ialah bahasa skrip yang berkuasa dan popular, tetapi seperti mana-mana teknologi lain, ia juga boleh menghadapi masalah prestasi. Untuk menyelesaikan masalah ini, adalah penting untuk mendiagnosisnya dengan cepat dan tepat. Artikel ini akan membimbing anda melalui satu set teknik yang berkesan untuk mendiagnosis isu prestasi PHP dengan cepat.
Xdebug ialah sambungan PHP berkuasa yang boleh memberikan data prestasi terperinci tentang pelaksanaan skrip. Untuk menggunakan Xdebug, ikuti langkah berikut:
pecl install xdebug
Selepas pemasangan, tambahkan yang berikut pada fail php.ini
anda: php.ini
文件中:
zend_extension=xdebug.so xdebug.profiler_enable=On xdebug.profiler_output_dir="/tmp" xdebug.profiler_output_name=cachegrind.out.%t.%s
运行脚本后,Xdebug 将在 /tmp
目录中生成一个 Cachegrind 输出文件(cachegrind.out.1fd460db7b2c2eba732e7ab84276e0af.397e8e0c84be29d4844e2f2e6080d586
)。您可以使用 KCacheGrind(一个免费的 GUI 工具)或 pprof --callgrind
命令来分析此输出文件。
Blackfire 是一个商业的 PHP 性能分析工具,提供了对请求执行的深入见解。要使用 Blackfire,请安装其 PHP 扩展并在您的脚本中添加以下代码:
use Blackfire\Client; $client = new Client(); $client->startProfile();
在脚本完成后,使用以下命令生成性能报告:
blackfire report -profile=/tmp/blackfire/<profile-id>
数据库查询可能是 PHP 性能问题的常见源泉。要检查查询,请使用 Xdebug 或 Blackfire 来查看执行的时间和数量。您还可以使用 MySQL 查询分析工具(如 pt-query-digest
)来识别低效查询。
内存使用过高会减慢脚本的执行速度。要分析内存使用情况,请使用 Xdebug 或 Blackfire 查看内存分配和峰值使用情况。您还可以使用 memory_get_peak_usage()
PHP 函数来检查脚本的最大内存使用量。
假设您有一个运行缓慢的 WordPress 网站。通过使用 Xdebug 分析 Cachegrind 输出,您发现一个加载了大量帖子的页面特别慢。进一步调查显示,.
符号之前的数据库表链接符(.
rrreee
cachegrind.out.1fd460db7b2c2eba732e7ab84276e0af.397e8e0c84be29d4844e2f2e6080d586
) dalam direktori /tmp
. Anda boleh menganalisis fail output ini menggunakan KCacheGrind (alat GUI percuma) atau perintah pprof --callgrind
. 🎜🎜3. Lihat jejak permintaan menggunakan Blackfire🎜🎜Blackfire ialah alat analisis prestasi PHP komersial yang memberikan cerapan mendalam tentang pelaksanaan permintaan. Untuk menggunakan Blackfire, pasang sambungan PHPnya dan tambahkan kod berikut pada skrip anda: 🎜rrreee🎜Selepas skrip selesai, hasilkan laporan prestasi menggunakan arahan berikut: 🎜rrreee🎜4 Semak pertanyaan pangkalan data 🎜🎜Pertanyaan pangkalan data boleh menjadi prestasi PHP Sumber masalah biasa. Untuk memeriksa pertanyaan, gunakan Xdebug atau Blackfire untuk melihat bila dan berapa kali ia dilaksanakan. Anda juga boleh menggunakan alatan analisis pertanyaan MySQL seperti pt-query-digest
untuk mengenal pasti pertanyaan yang tidak cekap. 🎜🎜5. Menganalisis penggunaan memori🎜🎜Penggunaan memori yang berlebihan akan melambatkan pelaksanaan skrip. Untuk menganalisis penggunaan memori, gunakan Xdebug atau Blackfire untuk melihat peruntukan memori dan penggunaan puncak. Anda juga boleh menggunakan fungsi PHP memory_get_peak_usage()
untuk menyemak penggunaan memori maksimum skrip anda. 🎜🎜Contoh Praktikal: Mendiagnosis Laman Web WordPress yang Lambat🎜🎜Andaikan anda mempunyai laman web WordPress yang perlahan. Dengan menggunakan Xdebug untuk menganalisis output Cachegrind, anda mendapati bahawa halaman yang memuatkan sejumlah besar siaran adalah sangat perlahan. Siasatan lanjut mendedahkan bahawa aksara pautan jadual pangkalan data (.
) sebelum simbol .
tiada, menyebabkan MySQL melaksanakan pertanyaan yang perlahan. Selepas membetulkan isu ini, kelajuan memuatkan halaman bertambah baik dengan ketara. 🎜Atas ialah kandungan terperinci Cara cepat mendiagnosis isu prestasi PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!