


Ein Artikel, der erklärt, wie man die Leistung von PHP7 optimiert und verbessert
PHP7 Als größtes Versions-Upgrade und größtes Leistungs-Upgrade von PHP seit 10 Jahren hat PHP7 in mehreren Tests offensichtliche Leistungsverbesserungen gezeigt. Um die Leistung zu maximieren, gibt es jedoch noch einige Dinge Ich möchte Sie daran erinnern.
1. Denken Sie daran, Zend Opcache zu aktivieren, da PHP7 auch ohne aktivierten Opcache schneller ist als PHP-5.6 mit aktiviertem Opcache. Dies geschah also im vorherigen Testzeitraum hat Opcache noch nie aktiviert. Das Aktivieren von Opcache ist sehr einfach.
Es wird empfohlen, einen neueren Compiler 4.8 oder höher zu verwenden, da dies nur für die Unterstützung von Global Register gilt aktiviert in PHP mit GCC 4.8 oder höher, was zu einer Leistungsverbesserung von 5 % führt (gemessen aus der QPS-Perspektive von Wordpres)
Tatsächlich wird es auch von Versionen vor GCC 4.8 unterstützt, aber wir haben festgestellt, dass es Folgendes unterstützt: Fehler, also Um diese Funktion zu aktivieren, muss Version 4.8 oder höher vorliegen Mein CentOS 6.5 als Beispiel. Weisen Sie 512 reservierten großen Seitenspeicher zu:zend_extension=opcache.so
opcache.enable=1
opcache.enable_cli=1"
$sudo sysctl vm.nr_hugepages=512
Dann fügen Sie php.ini hinzu:
Der Code lautet wie folgt:
$ cat /proc/meminfo | grep Huge AnonHugePages: 106496 kB HugePages_Total: 512 HugePages_Free: 504 HugePages_Rsvd: 27 HugePages_Surp: 0 Hugepagesize: 2048 kB
Auf diese Weise verwendet PHP große Speicherseiten um eigene Textsegmente und große Speicherzuweisungen zu speichern, um TLB-Fehler zu reduzieren und die Leistung zu verbessern.
Aktivieren Sie den Opcache-Datei-Cache (experimentell). Durch Aktivieren können wir Opcache den Opcode zwischenspeichern lassen Bei einigen Skripten wird es eine erhebliche Leistungsverbesserung geben: Der Code lautet wie folgt:opcache.huge_code_pages=1
opcache.file_cache=/tmp
$ make prof-gen
Das heißt, lassen Sie PHP-CGI die WordPress-Homepage 100 Mal ausführen um dabei einige Profilinformationen zu generieren.
Abschließend:
$ sapi/cgi/php-cgi -T 100 /home/huixinchen/local/www/htdocs/wordpress/index.php >/dev/null
Das PHP7, das Sie zu diesem Zeitpunkt kompilieren, ist die kompilierte Version mit der höchsten Leistung, die auf Ihr Projekt zugeschnitten ist.
Das obige ist der detaillierte Inhalt vonEin Artikel, der erklärt, wie man die Leistung von PHP7 optimiert und verbessert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Leistungsvergleich verschiedener Java-Frameworks: REST-API-Anforderungsverarbeitung: Vert.x ist am besten, mit einer Anforderungsrate von 2-mal SpringBoot und 3-mal Dropwizard. Datenbankabfrage: HibernateORM von SpringBoot ist besser als ORM von Vert.x und Dropwizard. Caching-Vorgänge: Der Hazelcast-Client von Vert.x ist den Caching-Mechanismen von SpringBoot und Dropwizard überlegen. Geeignetes Framework: Wählen Sie entsprechend den Anwendungsanforderungen. Vert.x eignet sich für leistungsstarke Webdienste, SpringBoot eignet sich für datenintensive Anwendungen und Dropwizard eignet sich für Microservice-Architekturen.

Der Leistungsvergleich der PHP-Methoden zum Umdrehen von Array-Schlüsselwerten zeigt, dass die Funktion array_flip() in großen Arrays (mehr als 1 Million Elemente) eine bessere Leistung als die for-Schleife erbringt und weniger Zeit benötigt. Die for-Schleifenmethode zum manuellen Umdrehen von Schlüsselwerten dauert relativ lange.

Zu den wirksamen Techniken zur Optimierung der C++-Multithread-Leistung gehört die Begrenzung der Anzahl der Threads, um Ressourcenkonflikte zu vermeiden. Verwenden Sie leichte Mutex-Sperren, um Konflikte zu reduzieren. Optimieren Sie den Umfang der Sperre und minimieren Sie die Wartezeit. Verwenden Sie sperrenfreie Datenstrukturen, um die Parallelität zu verbessern. Vermeiden Sie geschäftiges Warten und benachrichtigen Sie Threads über Ereignisse über die Ressourcenverfügbarkeit.

Die Leistung verschiedener PHP-Funktionen ist entscheidend für die Anwendungseffizienz. Zu den Funktionen mit besserer Leistung gehören echo und print, während Funktionen wie str_replace, array_merge und file_get_contents eine langsamere Leistung aufweisen. Beispielsweise wird die Funktion str_replace zum Ersetzen von Zeichenfolgen verwendet und weist eine mäßige Leistung auf, während die Funktion sprintf zum Formatieren von Zeichenfolgen verwendet wird. Die Leistungsanalyse zeigt, dass die Ausführung eines Beispiels nur 0,05 Millisekunden dauert, was beweist, dass die Funktion eine gute Leistung erbringt. Daher kann der kluge Einsatz von Funktionen zu schnelleren und effizienteren Anwendungen führen.

In PHP wirkt sich die Konvertierung von Arrays in Objekte auf die Leistung aus, die hauptsächlich von Faktoren wie Array-Größe, Komplexität, Objektklasse usw. beeinflusst wird. Um die Leistung zu optimieren, sollten Sie benutzerdefinierte Iteratoren verwenden und unnötige Konvertierungen, Batch-Konvertierung von Arrays und andere Techniken vermeiden.

Eine Möglichkeit, die Leistung von Java-Funktionen zu bewerten, ist die Verwendung der Java Microbenchmark Suite (JMH). Zu den spezifischen Schritten gehören: Hinzufügen von JMH-Abhängigkeiten zum Projekt. Erstellen Sie eine neue Java-Klasse und versehen Sie sie mit @State, um die Benchmark-Methode darzustellen. Schreiben Sie die Benchmark-Methode in die Klasse und kommentieren Sie sie mit @Benchmark. Führen Sie den Benchmark mit dem JMH-Befehlszeilentool aus.

Laut Benchmarks sind Quarkus (schneller Start, geringer Speicher) oder Micronaut (TechEmpower ausgezeichnet) für kleine, leistungsstarke Anwendungen die ideale Wahl. SpringBoot eignet sich für große Full-Stack-Anwendungen, weist jedoch etwas langsamere Startzeiten und Speichernutzung auf.

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