How to install and use xhprof performance analysis tool under PHP7
This article will introduce to you how to install and use the xhprof performance analysis tool under PHP7. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to everyone.
The xhprof version is obtained from https://github.com/longxinH/xhprof
git clone https://github.com/longxinH/xhprof
Install xhprof
cd xhprof/extension/ phpize ./configure make make install
and then Add
extension=xhprof.so
to /etc/php.ini according to the situation. Execute
php -m | grep xhprof
You can see the output, indicating that the php extension is installed successfully, and then restart Apache or php-fpm
Run
You can directly run the example in the example directory in the file cloned from github
The output is as follows
Array ( [main()] => Array ( [ct] => 1 [wt] => 9 ) ) --------------- Assuming you have set up the http based UI for XHProf at some address, you can view run at http://<xhprof-ui-address>/index.php?run=592567308784c&source=xhprof_foo ---------------
Then copy the ?run=592567308784c&source=xhprof_foo after index.php
Visit
xhprof_html/index.php?run=592567308784c&source=xhprof_foo
You can see the output
Click View Full Callgraph in the middle to see the performance analysis picture
Error reporting
failed to execute cmd:" dot -Tpng". stderr:sh: dot:command not found。
//解决方案 yum install graphviz
Adapt to changes
For example, if you want to test your own project, such as performance analysis of a framework.
Copy the two files under xhprof_lib/utils/
xhprof_lib.php and xhprof_runs.php to the same directory as the entry file, and then add
// start profiling xhprof_enable();
// stop profiler $xhprof_data = xhprof_disable(); // display raw xhprof data for the profiler run print_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_foo" $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo"); 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_foo\n". "---------------\n";
http://***/xhprof_html/index.php?run=*****&source=xhprof_foo
- Function Name: method name.
- Calls: The number of times the method has been called.
- Calls%: The number of method calls as a percentage of the total number of method calls at the same level.
- Incl.Wall Time (microsec): The time it takes for method execution, including the execution time of sub-methods. (Unit: microsecond)
- IWall%: The percentage of time spent in method execution.
- Excl. Wall Time (microsec): The time it takes to execute the method itself, excluding the execution time of sub-methods. (Unit: microsecond)
- EWall%: The percentage of time spent executing the method itself.
- Incl. CPU (microsecs): The CPU time spent on method execution, including the execution time of sub-methods. (Unit: microsecond)
- ICpu%: The percentage of CPU time spent in method execution.
- Excl. CPU (microsec): The CPU time spent executing the method itself, excluding the execution time of sub-methods. (Unit: microsecond)
- ECPU%: The percentage of CPU time spent executing the method itself.
- Incl.MemUse(bytes): The memory occupied by method execution, including the memory occupied by sub-method execution. (Unit: Bytes)
- IMemUse%: The percentage of memory occupied by method execution.
- Excl.MemUse(bytes): The memory occupied by the execution of the method itself, excluding the memory occupied by the execution of sub-methods. (Unit: Bytes)
- EMemUse%: The percentage of memory occupied by the method itself.
- Incl.PeakMemUse(bytes): Incl.MemUse peak value. (Unit: Bytes)
- IPeakMemUse%: Incl.MemUse peak percentage.
- Excl.PeakMemUse(bytes): Excl.MemUse peak value. Unit: (byte)
- EPeakMemUse%: Excl.MemUse peak percentage.
The above is the detailed content of How to install and use xhprof performance analysis tool under PHP7. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

Validator can be created by adding the following two lines in the controller.
