Heim > Artikel > Backend-Entwicklung > So verwenden Sie die XHProf-Analyse in PHP7
In diesem Artikel erfahren Sie, wie Sie die xhprof-Analyse in PHP7 verwenden. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.
Dies ist ein reines Dokument. Wenn Sie es in Zukunft benötigen, können Sie es jederzeit zur Analyse nachschlagen, um Codetests und Vergleichsanalysen zu erleichtern.
docker run -it -p 80:80 -v /Users/xxx/Desktop/xhprof:/data phalcon /bin/bash
Kopieren Sie den Code
Es gibt einige xhprofs, die PHP7 unterstützen.
1.1 Ziehen Sie das Projekt herunter
git clone https://github.com/longxinH/xhprof.git
Kopieren Sie den Code
1.2 Installieren Sie das Projekt
cd xhprof/extension/ /usr/server/php7/bin/phpize ./configure --with-php-config=/usr/server/php7/bin/php-config make && make install
1.3 Fügen Sie die Erweiterung xhprof.so hinzu
Schließlich müssen wir nach der Ausführung diese SO-Datei in die php.ini-Konfiguration einfügen
Ansicht php.ini-Dateipfad
/usr/server/php7/bin/php --ini Configuration File (php.ini) Path: /usr/server/php7/etc Loaded Configuration File: /usr/server/php7/etc/php.ini Scan for additional .ini files in: /usr/server/php7/etc/php Additional .ini files parsed: (none)
编辑 /usr/server/php7/etc/php.ini [Xhprof] extension=xhprof.so xhprof.output_dir=/data/logs
Starten Sie einfach php-fpm neu.
wird abgekürzt
Wir betten den folgenden Code vor der zu überwachenden Logik ein
\xhprof_enable(); ...... $order = new OrderAdepter(); $result = $order->getUserOrderByOrderNo(123); ...... $xhprof_data = \xhprof_disable(); print_r($xhprof_data);
Ausgabe:
Wir haben festgestellt, dass zwei Funktionen in der xhprof-Erweiterung vorhanden sind wurden aufgerufen, und die Bedeutung des Ausgabewerts
ct stellt die aktuelle Anzahl der Aufrufe dieser Funktion dar. In diesem Fall ist es alles 1 Mal
wt stellt die Ausführungszeit der Funktion dar, in Mikrosekunden Daher stellen wir fest, dass die Informationen, die wir erhalten, nicht sehr groß sind. Beispielsweise achten wir häufig auch auf den belegten Speicher, die CPU und andere Indikatoren
XHPROF_FLAGS_NO_BUILTINS zählt keine integrierten Funktionen, diese Ausgabe kann angezeigt werden. Da die Funktion in unserer Erweiterung ignoriert wurde , haben wir festgestellt, dass das Feld für die statistische Speichernutzung zwei Ausgaben hat: mu und pmu stellt den verwendeten Speicher (Bytes) dar, und pmu stellt die maximale Speichernutzung (Bytes) dar.
\xhprof_enable( XHPROF_FLAGS_MEMORY +XHPROF_FLAGS_CPU +XHPROF_FLAGS_NO_BUILTINS );Die Ausführung gibt eine Zeichenfolge aus, die wir als Datei verstehen können Identifikator. Wir stellen fest, dass die Methode save_run ausgeführt wird.
Wenn Sie interessiert sind, können Sie es öffnen und einen Blick darauf werfen. Einige der von uns analysierten Informationen sind darin gespeichert.
3.2 Konfigurieren Sie einen separaten Dienst um auf unsere Analyseergebnisse zuzugreifen
Wir verweisen auf das Verzeichnis xhprof_html in unserem xhprof-ProjektIch glaube, Sie verstehen unseren Standpunkt hier. Die Rolle des Projekts in run_id und save_run ist
Bedeutung des Feldnamens: Anzahl der Aufrufe inkl. Wall-Zeit, berechnet in Mikrosekunden in Mikrosekunden. Der Aufruf umfasst die gesamte von der Unterfunktion verbrauchte CPU-Zeit, mit Ausnahme der Ausführungszeit des Teilbaums. Inkl. MemUse umfasst den von der Unterfunktion verwendeten Speicher -Funktionsausführung, gemessen in Bytes Excl.MemUse Der Speicher der Funktionsausführung selbst, in Bytes, der Spitzenwert von Incl.PeakMemUseIncl.MemUse, der Spitzenwert von Excl.PeakMemUseExcl.MemUseDie Spitze Teil ist eine Übersicht über die angeforderten Schnittstellenindikatoren, und im Folgenden wird die spezifische Ausführung jeder aufgerufenen Funktion beschrieben.
Die verbleibenden %-Endungen sind die entsprechenden Proportionen
3.3 [Vollständigen Callgraph anzeigen]
Sie können auch die folgenden zwei Codezeilen zur Installation ausführen
\xhprof_enable(XHPROF_FLAGS_MEMORY + XHPROF_FLAGS_CPU+XHPROF_FLAGS_NO_BUILTINS); ...... $order = new OrderAdepter(); $result = $order->getUserOrderByOrderNo(123); ...... $xhprof_data = \xhprof_disable(); include_once '/data/xhprof-master/xhprof_lib/utils/xhprof_lib.php'; include_once '/data/xhprof-master/xhprof_lib/utils/xhprof_runs.php'; $xhprof_runs = new \XHProfRuns_Default(); $run_id = $xhprof_runs->save_run($xhprof_data, 'your_project'); echo $run_id; //output 5cbf25e21fe9bWenn Sie den Aufrufvorgang anzeigen möchten, müssen Sie die Graphviz-Grafikbibliothek installieren. Hier empfehlen wir die manuelle Installation graphviz 2.24.0-Version (persönlich in die Falle treten, 2.40 wird nicht unterstützt)
yum install -y libpng yum install -y graphviz
Der rote Teil Konzentrieren Sie sich auf den gelben Teil in eine Methode und klicken Sie dann auf [Vollständigen Aufrufgraphen anzeigen], um das Diagramm anzuzeigen
Hier können wir die Composer-Paketreferenz verwenden, um dieselbe Funktion zu erreichen. Es wird empfohlen, das Paket pbweb/xhprof einzuführen.
Empfohlenes Lernen:php-Video-Tutorial
Das obige ist der detaillierte Inhalt vonSo verwenden Sie die XHProf-Analyse in PHP7. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!