Table of Contents
Custom profile file name
Under Mac, MacCallGrind and qcachegrind can be used, but the former is charged and can be downloaded directly through the Apple Store, while the latter is free. Requires manual installation.
However, it should be noted that after turning on the
Home Backend Development PHP Tutorial About PHP+xdebug analysis of code performance bottlenecks

About PHP+xdebug analysis of code performance bottlenecks

Feb 18, 2021 pm 05:27 PM
php xdebug

PHP xdebug analysis code performance bottleneck

Usually enabledxdebug Plug-in, performance test output file will be generated, usually in the cachegrind.out.xxxx file.

This file can be used for code performance analysis through third-party tools.

But if there are multiple projects/websites locally, all profiles will be output to one file, which is not convenient for subsequent performance analysis.

Custom profile file name

You can set the output file name by configuring the xdebug.profiler_output_name parameter. Some parameters are as follows:

##%R#$_SERVER ['REQUEST_URI']cachegrind.out.%Rcachegrind.out._test_xdebug_test_php_var=1_var2%S session_id (from $_COOKIE if set)cachegrind.out.%Scachegrind.out.c70c1ec2375af58f74b390bbdd2a679d%%%characterscachegrind.out.%%cachegrind.out.%%##edit
Symbol Meaning Configuration sample Sample file name
%c Crc32 check value of the current working directory cachegrind.out.%c cachegrind.out.1258863198
% p Pid of the current server process cachegrind.out.%p cachegrind.out.9685
%r Random number cachegrind.out.%r cachegrind.out.072db0
%s Script file name (note) cachegrind.out.%s cachegrind.out._home_httpd_html_test_xdebug_test_php
%t Unix Timestamp (seconds) cachegrind.out.%t cachegrind.out.1179434742
%u Unix time Stamp (microseconds) cachegrind.out.%u cachegrind.out.1179434749_642382
%H $_SERVER ['HTTP_HOST'] cachegrind.out.%H cachegrind.out.localhost
php. ini

Configuration file: <pre class="brush:php;toolbar:false">xdebug.profiler_output_name = cachegrind.out.%H</pre> Then restart the php server.

Under Mac, the profile file is stored in the

/var/tmp/

directory. Performance Analysis

Under Mac, MacCallGrind and qcachegrind can be used, but the former is charged and can be downloaded directly through the Apple Store, while the latter is free. Requires manual installation.

Install graphviz for Call Graph function:

$ brew install graphviz

Install qcachegrind:

$ brew install qcachegrind

After the installation is completed, you can open the

qcachegrind

application, graph The interface is as follows:

About PHP+xdebug analysis of code performance bottlenecksOthers

However, it should be noted that after turning on the

profile

file output, if there are many local projects, it is easy to It occupies a large area of ​​disk space. The picture below shows the status that I haven’t cleaned up in about half a year:

About PHP+xdebug analysis of code performance bottlenecksYou can use the command to clean up:

$ sudo rm -fr /private/var/tmp/cachegrind.out.*

The above is the detailed content of About PHP+xdebug analysis of code performance bottlenecks. For more information, please follow other related articles on the PHP Chinese website!

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

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What are public, private, and protected in php What are public, private, and protected in php Aug 24, 2025 am 03:29 AM

Public members can be accessed at will; 2. Private members can only be accessed within the class; 3. Protected members can be accessed in classes and subclasses; 4. Rational use can improve code security and maintainability.

How to execute an UPDATE query in php How to execute an UPDATE query in php Aug 24, 2025 am 05:04 AM

Using MySQLi object-oriented method: establish a connection, preprocess UPDATE statements, bind parameters, execute and check the results, and finally close the resource. 2. Using MySQLi procedure method: connect to the database through functions, prepare statements, bind parameters, perform updates, and close the connection after processing errors. 3. Use PDO: Connect to the database through PDO, set exception mode, pre-process SQL, bind parameters, perform updates, use try-catch to handle exceptions, and finally release resources. Always use preprocessing statements to prevent SQL injection, verify user input, and close connections in time.

How to use cURL in php How to use cURL in php Aug 24, 2025 am 08:32 AM

cURLinPHPenablessendingHTTPrequests,fetchingAPIdata,anduploadingfiles.Initializewithcurl_init(),setoptionslikeCURLOPT_URLandCURLOPT_RETURNTRANSFER,useCURLOPT_POSTforPOSTrequests,sendJSONwithproperheaders,handleerrorsviacurl_errno()andHTTPcodeswithcur

How to read a CSV file in PHP? How to read a CSV file in PHP? Aug 29, 2025 am 08:06 AM

ToreadaCSVfileinPHP,usefopen()toopenthefile,fgetcsv()inalooptoreadeachrowasanarray,andfclose()tocloseit;handleheaderswithaseparatefgetcsv()callandspecifydelimitersasneeded,ensuringproperfilepathsandUTF-8encodingforspecialcharacters.

How to use AJAX with php How to use AJAX with php Aug 29, 2025 am 08:58 AM

AJAXwithPHPenablesdynamicwebappsbysendingasynchronousrequestswithoutpagereloads.1.CreateHTMLwithJavaScriptusingfetch()tosenddata.2.BuildaPHPscripttoprocessPOSTdataandreturnresponses.3.UseJSONforcomplexdatahandling.4.Alwayssanitizeinputsanddebugviabro

Edit bookmarks in chrome Edit bookmarks in chrome Aug 27, 2025 am 12:03 AM

Chrome bookmark editing is simple and practical. Users can enter the bookmark manager through the shortcut keys Ctrl Shift O (Windows) or Cmd Shift O (Mac), or enter through the browser menu; 1. When editing a single bookmark, right-click to select "Edit", modify the title or URL and click "Finish" to save; 2. When organizing bookmarks in batches, you can hold Ctrl (or Cmd) to multiple-choice bookmarks in the bookmark manager, right-click to select "Move to" or "Copy to" the target folder; 3. When exporting and importing bookmarks, click the "Solve" button to select "Export Bookmark" to save as HTML file, and then restore it through the "Import Bookmark" function if necessary.

What is the difference between isset and empty in php What is the difference between isset and empty in php Aug 27, 2025 am 08:38 AM

isset()checksifavariableexistsandisnotnull,returningtrueevenforzero,false,oremptystringvalues;2.empty()checksifavariableisnull,false,0,"0","",orundefined,returningtrueforthese"falsy"values;3.isset()returnsfalsefornon-exi

How to configure SMTP for sending mail in php How to configure SMTP for sending mail in php Aug 27, 2025 am 08:08 AM

Answer: Using the PHPMailer library to configure the SMTP server can enable sending mails through SMTP in PHP applications. PHPMailer needs to be installed, set up SMTP host, port, encryption method and authentication credentials of Gmail, write code to set sender, recipient, topic and content, enable 2FA and use application password to ensure that the server allows SMTP connection, and finally call the send method to send email.

See all articles