Heim > Backend-Entwicklung > PHP7 > Hauptteil

So verwenden Sie die XHProf-Analyse in PHP7

醉折花枝作酒筹
Freigeben: 2023-02-18 06:30:02
nach vorne
1437 Leute haben es durchsucht

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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)
Nach dem Login kopieren
编辑 /usr/server/php7/etc/php.ini
[Xhprof]
extension=xhprof.so
xhprof.output_dir=/data/logs
Nach dem Login kopieren

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);
Nach dem Login kopieren

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
    );
    Nach dem Login kopieren

    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
Nach dem Login kopieren

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
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!