Introduction to installing xhprof for performance analysis in PHP 7.1

不言
Release: 2023-04-02 12:10:02
Original
1669 people have browsed it

This article mainly introduces the introduction of installing xhprof for performance analysis in PHP 7.1. It has a certain reference value. Now I share it with you. Friends in need can refer to it

Install Extension
The xhprof extension version is obtained from https://github.com/longxinH/xhprof (a third-party library, the official version does not support php7)

Download and compile the xhprof extension
Operation in the html directory of the web:
git clone https://github.com/longxinH/xhprof

Compile extension

cd xhprof/extension/phpize
./configure 
makemake install
Copy after login

Modify php.ini configuration

[xhprof]
extension=xhprof.so;
xhprof.output_dir=/tmp/xhprof
Copy after login

xhprof.output_dir is the output directory of xhprof. Each time the save_run method of xhprof is executed, a run_id.project_name.xhprof file will be generated. It doesn't matter where this directory is. Note that the permissions of this path must be readable and writable! ! Otherwise, the file cannot be generated successfully

Restart php-fpm
sudo service php7.1-fpm restart

Add test code

<?php
xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);// 要检查性能的代码
$xhprof_data = xhprof_disable();
include_once &#39;/var/www/html/xhprof/xhprof_lib/utils/xhprof_lib.php&#39;;
include_once &#39;/var/www/html/xhprof/xhprof_lib/utils/xhprof_runs.php&#39;;
$xhprof_runs = new \XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, &#39;your_project&#39;);
Copy after login

Two files, xhprof_lib.php and xhprof_runs.php, need to be introduced into the test code

View the generated report
Required Visit: xhprof/xhprof_html/index.php file view:
http://localhost/xhprof/xhprof_html/index.php?run=5b35d3dfa8c29&source=your_project
The parameter after run is $run_id, and the source parameter is your_project configuration The name

If the graph is generated incorrectly, you need to install the plug-in:
sudo apt-get install graphviz

Actual demonstration code

<?php
function test1(){
for($i=0;$i<10;$i++){
echo &#39;aaa&#39;.$i.&#39;<br>&#39;;
}
}// start profilingxhprof_enable();

test1();
// stop profiler
$xhprof_data = xhprof_disable();
// display raw xhprof data for the profiler runprint_r($xhprof_data);
include_once "xhprof_lib.php";include_once "xhprof_runs.php";
// save raw data for this profiler run using default
// implementation of iXHProfRuns.
$xhprof_runs = new XHProfRuns_Default();
// save the run under a namespace "xhprof_test"
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_test");echo "---------------\n".
"Assuming you have set up the http based UI for \n".
"XHProf at some address, you can view run at \n".
"http://<xhprof-ui-address>/index.php?run=$run_id&source=xhprof_test\n".
"---------------\n";
Copy after login

The above is the entire content of this article. I hope it will be helpful to everyone's study. For more related content, please pay attention to the PHP Chinese website!

Related recommendations:

The difference and installation of LAMP, LNMP and LNAMP

Use Wamp to build a Php local development environment and HBuilder debugging method

The above is the detailed content of Introduction to installing xhprof for performance analysis in PHP 7.1. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!