Heim  >  Artikel  >  Backend-Entwicklung  >  So verwenden Sie die XHProf-Analyse in PHP7

So verwenden Sie die XHProf-Analyse in PHP7

醉折花枝作酒筹
醉折花枝作酒筹nach vorne
2021-06-18 09:33:321480Durchsuche

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.

So verwenden Sie die XHProf-Analyse in PHP7

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.

Erstellen Sie einen virtuellen Docker Testumgebung im Voraus

docker run -it -p 80:80 -v /Users/xxx/Desktop/xhprof:/data phalcon /bin/bash

Kopieren Sie den Code

1. Installieren Sie xhprof

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.

2. Der Prozess zum Erstellen eines Falls mit xhprof

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.
  1. Verwenden Sie es.

    3.1 Zu diesem Zeitpunkt müssen wir die xhprof_lib-Bibliothek verwenden.
  2. Laden wir den xhprof-Quellcode herunter. Zu diesem Zeitpunkt enthält das Verzeichnis bereits

    \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.
  3. Sie erinnern sich noch daran, dass wir während der Erweiterung eine andere Konfiguration eingeführt haben.

    Ja, unter dem von xhprof.output_dir konfigurierten Pfad (um das Verzeichnis manuell zu erstellen)

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-Projekt

Ich glaube, Sie verstehen unseren Standpunkt hier. Die Rolle des Projekts in run_id und save_run ist

Die Spitze Teil ist eine Übersicht über die angeforderten Schnittstellenindikatoren, und im Folgenden wird die spezifische Ausführung jeder aufgerufenen Funktion beschrieben.

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.MemUse

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 5cbf25e21fe9b

Wenn 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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen