Home  >  Article  >  Backend Development  >  Introduction to installing xhprof for performance analysis in PHP 7.1

Introduction to installing xhprof for performance analysis in PHP 7.1

不言
不言Original
2018-07-04 17:18:281670browse

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

Modify php.ini configuration

[xhprof]
extension=xhprof.so;
xhprof.output_dir=/tmp/xhprof

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;);

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";

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!

Statement:
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