Inhaltsverzeichnis
mongo服务器的配置
Heim Backend-Entwicklung PHP7 Wie teste ich mit xhprof die PHP-Leistung in PHP7? (Methodeneinführung)

Wie teste ich mit xhprof die PHP-Leistung in PHP7? (Methodeneinführung)

Jul 15, 2020 pm 05:11 PM
php7 php性能

Wie teste ich mit xhprof die PHP-Leistung in PHP7? (Methodeneinführung)

Einführung

1 Hintergrund

  • PHPs xhprof-Erweiterung Facebook wird nicht mehr aktualisiert und gewartet, da Facebook HHVM vollständig genutzt hat und die PHP-Zend-Engine nicht mehr verwendet.

  • xhprof unterstützt nicht die neue Version von PHP (PHP7). Die Tideways-Erweiterung ist aus dem xhprof-Projekt abgezweigt und wird derzeit weiterhin unterstützt. 5.6 und 5.5.

  • tideways ist ein Open-Source-Projekt, das nur UI-Dienste in Rechnung stellt. Tatsächlich kann xhgui unseren täglichen Bedarf vollständig decken

2 Funktionen

Tideways ist eine Erweiterung zum Testen der PHP-Leistung. Sie kann die während des gesamten Prozesses der PHP-Ausführung aufgerufenen Funktionen, die Anzahl der Funktionsaufrufe und die Ausführungszeit ermitteln , CPU-Zeit und Speichernutzung, Speicherspitze, Gesamtausführungszeit, Gesamt-CPU-Zeit, Gesamtspeichernutzung, Gesamtspeicherspitze und andere Daten. Analysieren Sie die oben genannten Daten, um den Leistungsengpass von PHP herauszufinden, und analysieren Sie den PHP-Ausführungsprozess. usw.

3 Vorteile

  • tideways ist eine PHP-Erweiterung, die in Kombination mit xhgui nicht vergraben werden muss Der PHP-Code Der Überwachungscode

  • kann die Ausführungshäufigkeit festlegen (z. B. 1/100), ohne für jede Anfrage Ausführungsprotokolle zu generieren, was zu Leistungsverlusten führt um Ausführungsprotokolle zu generieren, indem Parameter zur Steuerung angefordert werden (debug=1)

  • Es gibt eine einfache und direkte Benutzeroberfläche zum Transformieren von Daten

  • Das können Sie Passen Sie die Bedingungen für die Datenfilterung frei an. Analysieren Sie beispielsweise eine bestimmte Schnittstelle, analysieren Sie die Schnittstellenanforderungssituation in einem bestimmten Zeitraum usw.

4 Nachteile

Obwohl nicht aufdringlich, wenn für jede Schnittstelle Ausführungsprotokolle generiert werden, ist der Verbrauch von CPU und Speicher nicht zu vernachlässigen.

5 Implementierungsprinzip

  • Tideways-Erweiterung ist für die Generierung laufender Protokolle verantwortlich
  • In Nginx fastcgi_param PHP_VALUE auto_prepend_file Wird konfiguriert, führen Sie die mit auto_prepend_file konfigurierte PHP-Datei aus, bevor die Anforderung gestartet wird. Am Ende des PHP-Prozesses wird Tideways_disable aufgerufen, um die Einbettung von Tideways zu realisieren oder MySQL oder eine Datei und wird nach der Analyse durch xhgui angezeigt. Zu den Anzeigeformaten gehören Balkendiagramm, Wasserfallfluss und Flammendiagramm.

Anwendung

Die folgenden zwei Anwendungsmethoden werden vorgestellt: Intrusiv und Nicht-invasiv

Der aufdringliche Modus bezieht sich auf das Hinzufügen von Code zum Code, und der aufdringliche Modus verwendet die Standard-Benutzeroberfläche.

Der nicht aufdringliche Modus bezieht sich darauf, keine Änderungen am Code vorzunehmen /apache zur nichtinvasiven Implementierung von Code-Injection;

Installieren Sie tideways_xhprof

git clone "https://github.com/tideways/php-xhprof-extension.git"
cd php-xhprof-extension
phpize
./configure --with-php-config=/usr/local/php7/bin/php-config
make
sudo make install
Nach dem Login kopieren

Fügen Sie die Erweiterung=tideways_xhprof.so

Nicht aufdringlich:

<?php
tideways_xhprof_enable();

// your application code

$data = tideways_xhprof_disable();
file_put_contents(
    sys_get_temp_dir() . "/" . uniqid() . ".yourapp.xhprof",
    serialize($data)
);

  // $data = tideways_xhprof_disable();
  // file_put_contents(
  //     sys_get_temp_dir() . "/" . date(&#39;His&#39;, time()) . ".material.xhprof",
  //     serialize($data)
  // );
Nach dem Login kopieren

Die hier generierte .xhprof-Datei befindet sich im tmp-Verzeichnis

Installieren Sie die Standard-Benutzeroberfläche zum Suchen von Daten

git clone git@github.com:phacility/xhprof.git
Nach dem Login kopieren

Installieren Sie die Verzeichnisse

und xhprof_lib aus diesem Repository in Ihrem Webordner und Navigieren Sie zu xhprof_html, um die Liste der Spuren anzuzeigen. xhprof_html/index.php

Wenn Sie Funktionsaufrufnotizen sehen möchten, müssen Sie Callgraph installieren

Callgraph installieren

Callgraph ist eigentlich ein Kombination aus drei Werkzeugen werden.

Eine davon ist cflow oder calltree, die zum Generieren eines C-Funktionsaufrufbaums verwendet wird. Im Folgenden wird hauptsächlich cflow vorgestellt.

Ein Tool zum Arbeiten mit der Punkttext-Grafiksprache, erweitert durch graphviz.

Ein Skript zum Konvertieren des C-Funktionsaufrufbaums in das Punktformat: tree2dotx

Nehmen Sie Ubuntu als Beispiel und installieren Sie sie entsprechend:

sudo apt-get install cflow graphviz
Nach dem Login kopieren

Als nächstes installieren Sie tree2dotx und Callgraph, hier sind sie werden standardmäßig nach /usr/local/bin installiert.

wget -c https://github.com/tinyclub/linux-0.11-lab/raw/master/tools/tree2dotx
wget -c https://github.com/tinyclub/linux-0.11-lab/raw/master/tools/callgraph
sudo cp tree2dotx callgraph /usr/local/bin
sudo chmod +x /usr/local/bin/{tree2dotx,callgraph}
Nach dem Login kopieren

Die folgenden zwei Darstellungen werden angezeigt:

> Aufdringliche Verwendung von xhgui erfordert mongodb

Installieren Sie xhgui

git clone git@github.com:perftools/xhgui.git
Nach dem Login kopieren

Nginx konfigurieren

server {
  listen 80;
  server_name site.localhost;
  root /Users/markstory/Sites/awesome-thing/app/webroot/;
  fastcgi_param PHP_VALUE "auto_prepend_file=/home/www/xhgui/external/header.php";  #这里依据个人目录而配
}
Nach dem Login kopieren
Das bedeutet hier, header.php auszuführen, bevor der Projekt-PHP-Code ausgeführt wird, also z um den Zweck einer nicht-invasiven Erkennungsleistung zu erreichen

xhgui-Konfiguration (Häufigkeit der Protokollgenerierung)

In xhguis config/config.default. php, die Anzahl der Sampling-Hits kann eingestellt werden;

return rand(1, 100) === 42; 为1%的采样率,改成return True;则标识每次都采样

&#39;profiler.enable&#39; => function() {
   // url 中包含debug=1则百分百捕获
   if(!empty($_GET['debug'])){
       return True;
   }else{
       // 1%采样
       return rand(1, 100) === 42;
   }
}
Nach dem Login kopieren

mongodb的配置

   xhgui/config/config.default.php

// Can be either mongodb or file.
   /*
   'save.handler' => 'file',
   'save.handler.filename' => dirname(__DIR__) . '/cache/' . 'xhgui.data.' . microtime(true) . '_' . substr(md5($url), 0, 6),
   */
   'save.handler' => 'mongodb',
   // Needed for file save handler. Beware of file locking. You can adujst this file path
   // to reduce locking problems (eg uniqid, time ...)
   //'save.handler.filename' => __DIR__.'/../data/xhgui_'.date('Ymd').'.dat',
   'db.host' => 'mongodb://127.0.0.1:27017',
   'db.db' => 'xhprof',
Nach dem Login kopieren

mongo服务器的配置

mongo
 > use xhprof
 > db.results.ensureIndex( { 'meta.SERVER.REQUEST_TIME' : -1 } )
 > db.results.ensureIndex( { 'profile.main().wt' : -1 } )
 > db.results.ensureIndex( { 'profile.main().mu' : -1 } )
 > db.results.ensureIndex( { 'profile.main().cpu' : -1 } )
 > db.results.ensureIndex( { 'meta.url' : 1 } )
Nach dem Login kopieren

最后展示几张xhgui的效果图

 

 

 

 相关学习推荐:PHP编程从入门到精通

Das obige ist der detaillierte Inhalt vonWie teste ich mit xhprof die PHP-Leistung in PHP7? (Methodeneinführung). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was soll ich tun, wenn das Plug-in in php7.0 installiert ist, aber immer noch angezeigt wird, dass es nicht installiert ist? Was soll ich tun, wenn das Plug-in in php7.0 installiert ist, aber immer noch angezeigt wird, dass es nicht installiert ist? Apr 02, 2024 pm 07:39 PM

So beheben Sie das Problem, dass das Plugin in PHP 7.0 nicht installiert ist: Überprüfen Sie die Plugin-Konfiguration und aktivieren Sie das Plugin. Starten Sie PHP neu, um die Konfigurationsänderungen zu übernehmen. Überprüfen Sie die Berechtigungen der Plugin-Datei, um sicherzustellen, dass sie korrekt sind. Installieren Sie fehlende Abhängigkeiten, um sicherzustellen, dass das Plugin ordnungsgemäß funktioniert. Wenn alle anderen Schritte fehlschlagen, erstellen Sie PHP neu. Weitere mögliche Ursachen sind inkompatible Plugin-Versionen, das Laden der falschen Version oder PHP-Konfigurationsprobleme.

So lösen Sie das Problem, wenn PHP7 erkennt, dass der TCP-Port nicht funktioniert So lösen Sie das Problem, wenn PHP7 erkennt, dass der TCP-Port nicht funktioniert Mar 22, 2023 am 09:30 AM

In PHP5 können wir die Funktion fsockopen() verwenden, um den TCP-Port zu erkennen. Mit dieser Funktion können Sie eine Netzwerkverbindung herstellen und eine Netzwerkkommunikation durchführen. In PHP7 kann die Funktion fsockopen() jedoch auf einige Probleme stoßen, z. B. dass der Port nicht geöffnet werden kann, keine Verbindung zum Server hergestellt werden kann usw. Um dieses Problem zu lösen, können wir die Funktionen socket_create() und socket_connect() verwenden, um den TCP-Port zu erkennen.

So installieren Sie die Mongo-Erweiterung in PHP7.0 So installieren Sie die Mongo-Erweiterung in PHP7.0 Nov 21, 2022 am 10:25 AM

So installieren Sie die Mongo-Erweiterung in PHP7.0: 1. Erstellen Sie die Mongodb-Benutzergruppe und den Mongodb-Benutzer. 2. Laden Sie das Mongodb-Quellcodepaket herunter und platzieren Sie das Quellcodepaket im Verzeichnis „/usr/local/src/“. Geben Sie das Verzeichnis „src/“ ein. 4. Entpacken Sie das Quellcodepaket. 6. Kopieren Sie die Dateien in das Verzeichnis „mongodb/“.

So verwenden Sie PHP zur Leistungsanalyse und -optimierung So verwenden Sie PHP zur Leistungsanalyse und -optimierung Jun 06, 2023 pm 01:21 PM

Als beliebte serverseitige Sprache spielt PHP eine wichtige Rolle bei der Entwicklung und dem Betrieb von Websites. Da jedoch die Menge an PHP-Code immer weiter zunimmt und die Komplexität der Anwendungen zunimmt, wird es immer wahrscheinlicher, dass es zu Leistungsengpässen kommt. Um dieses Problem zu vermeiden, müssen wir eine Leistungsanalyse und -optimierung durchführen. In diesem Artikel wird kurz vorgestellt, wie Sie PHP zur Leistungsanalyse und -optimierung verwenden, um eine effizientere Ausführungsumgebung für Ihre Anwendungen bereitzustellen. 1. PHP-Leistungsanalysetool 1.XdebugXdebug ist ein weit verbreitetes Codeanalysetool.

FAQ-Leitfaden zur PHP-Serverumgebung: Häufige Probleme schnell lösen FAQ-Leitfaden zur PHP-Serverumgebung: Häufige Probleme schnell lösen Apr 09, 2024 pm 01:33 PM

Zu den gängigen Lösungen für PHP-Serverumgebungen gehört die Sicherstellung, dass die richtige PHP-Version installiert ist und relevante Dateien in das Modulverzeichnis kopiert wurden. Deaktivieren Sie SELinux vorübergehend oder dauerhaft. Überprüfen und konfigurieren Sie PHP.ini, um sicherzustellen, dass die erforderlichen Erweiterungen hinzugefügt und korrekt eingerichtet wurden. Starten oder starten Sie den PHP-FPM-Dienst neu. Überprüfen Sie die DNS-Einstellungen auf Auflösungsprobleme.

So installieren und implementieren Sie PHP7.0 So installieren und implementieren Sie PHP7.0 Nov 30, 2022 am 09:56 AM

So installieren und implementieren Sie PHP7.0: 1. Gehen Sie zur offiziellen PHP-Website, um die dem lokalen System entsprechende Installationsversion herunterzuladen. 2. Extrahieren Sie die heruntergeladene ZIP-Datei in das angegebene Verzeichnis. 3. Öffnen Sie das Befehlszeilenfenster und gehen Sie zu das Verzeichnis „E:\php7“ Führen Sie einfach den Befehl „php -v“ aus.

Wie setze ich nach dem Neustart des Systems automatisch Berechtigungen von Unixsocket fest? Wie setze ich nach dem Neustart des Systems automatisch Berechtigungen von Unixsocket fest? Mar 31, 2025 pm 11:54 PM

So setzen Sie die Berechtigungen von Unixsocket automatisch nach dem Neustart des Systems. Jedes Mal, wenn das System neu startet, müssen wir den folgenden Befehl ausführen, um die Berechtigungen von Unixsocket: sudo ...

Was ist besser, PHP8 oder PHP7? Was ist besser, PHP8 oder PHP7? Nov 16, 2023 pm 03:09 PM

Im Vergleich zu PHP7 bietet PHP8 einige Vorteile und Verbesserungen in Bezug auf Leistung, neue Funktionen und Syntaxverbesserungen, Typsystem, Fehlerbehandlung und Erweiterungen. Die Wahl der zu verwendenden Version hängt jedoch von Ihren spezifischen Anforderungen und Projektumständen ab. Detaillierte Einführung: 1. Leistungsverbesserung: PHP8 führt den Just-in-Time-Compiler (JIT) ein, der die Ausführungsgeschwindigkeit des Codes verbessern kann. 2. Neue Funktionen und Syntaxverbesserungen. PHP8 unterstützt die Deklaration benannter Parameter und optionaler Parameter. Durch die flexiblere Gestaltung von Funktionen werden anonyme Klassen, Typdeklarationen von Eigenschaften usw. eingeführt.

See all articles