Inhaltsverzeichnis
WEBOptimierungsregeln der Rezeption1. " >Kapitel 2Optimierungsregeln der Rezeption1.
Seitenanforderungsanalyse " >A Seitenanforderungsanalyse
Heim Web-Frontend CSS-Tutorial Detaillierte Einführung in Lösungen zur Web-Performance-Optimierung

Detaillierte Einführung in Lösungen zur Web-Performance-Optimierung

Jul 27, 2017 am 09:39 AM
web 方案 详细

Kapitel 1 Analyse des langsamen Status der Website öffnen

Wenn das Unternehmen auf die im IDC-Computerraum bereitgestellte VIP-Website zugreift, wird es sich sehr langsam anfühlen. Was verursacht das? Um die Reaktionszeit der Seite zu verkürzen und unser Benutzererlebnis zu verbessern, müssen wir wissen, worauf Benutzer warten.

Sie können unsere Anmeldeseite verfolgen, wie unten gezeigt

Aus dem obigen Bild können wir HTMLDokumente machen nur 20 % der gesamten Antwortzeit aus, und die anderen 80 % Antwortzeit werden zum Herunterladen von JS, CSS, Bilder usw. Komponenten. Daher gibt es im Front-End von WEB viel Raum für Optimierungen. Wir werden einen Leistungsoptimierungsplan für WEB sowohl für die Front-End-Optimierung als auch für das Back-End erstellen Optimierung von WEB.

Kapitel 2Optimierungsregeln der Rezeption1.

Minimieren

HTTP-Anfragen

Es gibt mehrere gängige Methoden, um tatsächlich Anfrage: 1

,

Skript- und Stildateien zusammenführen, zum Beispiel können Sie mehrere CSS -Dateien zusammenfassen Eins: Kombinieren Sie mehrere JS -Dateien zu einer. 2

,

CSS Sprites Verwenden Sie CSS-Hintergrund verwandte Elemente, um das Hintergrundbild absolut zu positionieren , um mehrere Bilder zu kombinieren ein Bild. 2.

Browser-Cache verwenden

 Wenn Benutzer verschiedene Seiten der Website durchsuchen, werden viele Inhalte wiederholt, z. B. dasselbe JS, CSS, Bilder usw. Wenn wir Browsern vorschlagen oder sogar zwingen könnten, diese Dateien lokal zwischenzuspeichern, würde dies den von der Seite generierten Datenverkehr erheblich reduzieren und damit die Seitenladezeiten verkürzen.

Gemäß dem serverseitigen Antwort-Header weist eine Datei mehrere verschiedene Ebenen des Cache-Status für den Browser auf.

1 Der Server weist den Browser an, diese Datei nicht zwischenzuspeichern und die Datei jedes Mal auf dem Server zu aktualisieren.

2 Der Server gibt keine Anweisungen an den Browser.

3 Bei der letzten Übertragung sendete der Server die Daten Last-Modified oder Etag Daten werden an den Server übermittelt, um zu überprüfen, ob die lokale Version die neueste ist. Wenn es sich um die neueste handelt, gibt der Server den Code 304 zurück und weist den Browser an, die lokale Version direkt zu verwenden. Andernfalls wird die Version heruntergeladen neue Version. Wenn nur statische Dateien vorhanden sind, stellt der Server im Allgemeinen diese Daten bereit.

4 Der Server zwingt den Browser, Dateien zwischenzuspeichern, und legt eine Ablaufzeit fest. Bevor der Cache abläuft, verwendet der Browser direkt die lokale Cache-Datei, ohne dass eine Kommunikation mit dem Server erfolgt.

 Wir müssen versuchen, den Browser in den vierten Zustand zu zwingen, insbesondere für JS, CSS, Bilder und andere Änderungen Das sind relativ große Weniger Dateien.

3. Komprimierungskomponenten verwenden

IE und Firefox-Browser unterstützen beide ClientGZIP, Verwenden Sie vor der Übertragung GZIP, um es zu komprimieren und dann an den Client zu übertragen. Nachdem der Client es empfangen hat, wird es vom Browser dekomprimiert, obwohl dies etwas von der CPU beansprucht des Servers und des Clients ändert sich dadurch nichts. Es kommt zu einer höheren Bandbreitenauslastung. Bei reinem Text ist die Komprimierungsrate ziemlich beeindruckend. Wenn jeder Benutzer 50 % an Bandbreite einspart, kann die gemietete Bandbreite doppelt so viele Kunden bedienen und die Datenübertragungszeit verkürzen.

4. Vorabladen von Bildern und JS

Der einfachste Weg, Bilder vorab zu laden, ist Instanziieren a neues Image() -Objekt in JavaScript und übergeben Sie dann die URL des zu ladenden Bildes als Parameter.

function preLoadImg(url) {
var img = new Image();
img.src = url;
}
Nach dem Login kopieren


Sie können JS und Bilder auf der Anmeldeseite vorladen

5 , Platzierung des Skripts unten

Probleme, die durch die Platzierung des Skripts oben verursacht werden,

1, Bei der Verwendung von Skripten wird das progressive Rendering für Inhalte blockiert, die sich unterhalb des Skripts befinden

2, blockiert parallele Downloads während des Herunterladens des Skripts

unten platziert kann einen JS-Fehler verursachen. Wenn das Skript nicht geladen ist, löst der Benutzer das Skriptereignis aus.

Betrachten Sie die Situation umfassend.

6. Platzieren Sie die Stildatei oben auf der Seite

Wenn das Stylesheet nicht geladen ist, ist das Erstellen des Rendering-Baums eine Verschwendung. Es kann zwei Situationen geben, in denen die Style-Datei am Ende der Seite platziert wird:

1 , Weißer Bildschirm

2. Flashen von nicht gestyltem Inhalt

7 Verwenden Sie externes

JS und CSS

, um das Inline-

JS und CSS in externes JS umzuwandeln , CSS. Reduzieren Sie wiederholte Downloads von Inline-JS und CSS. 8.

Komponenten in mehrere Domänen aufteilen

Der Hauptzweck besteht darin, die Fähigkeit zum parallelen Herunterladen von Seitenkomponenten zu verbessern. Überspannen Sie jedoch nicht zu viele Domainnamen. Es wird empfohlen, Subdomainnamen zu verwenden.

9.

Streamlining

kann zwei Dinge bewirken Ebenen

1

, rationalisieren: Entfernen Sie unnötige Zeichen aus dem Code, um seine Größe zu reduzieren,

2

, Verschleierung: Beim Optimieren wird auch der Code neu geschrieben und Funktions- und Variablennamen werden in kürzere Strings umgewandelt

10.

Optimieren

Entfernen Sie unnötige Zeichen aus dem Code, um seine Größe zu reduzieren,

Elf,

Bild optimieren,

Achten Sie bei großen Bildern auf ein Gleichgewicht zwischen Effekt und Größe.

Kapitel 3Optimierung des Programms

Kapitel 4

Datenbankoptimierung

Anhang

A Seitenanforderungsanalyse

Von der Eingabe

URL erfordert die folgenden 5 Schritte zum Rendern auf der Seite1

.

Geben Sie die URL-Adresse ein oder klicken Sie auf einen Link von URL

 

2. Der Browser analysiert die IPAdresse URL

entspricht, basierend auf der URL-Adresse, kombiniert mit DNS 🎜> 

3

. HTTP-Anfrage senden  

4

. Stellen Sie eine Verbindung zum angeforderten Server her und fordern Sie zugehörige Inhalte an

 5 Der Browser analysiert den vom Server zurückgegebenen Inhalt und zeigt die Seite an

Das Obige ist im Grunde der grundlegende Prozess einer Seite von der Anfrage bis zur Implementierung. Im Folgenden werden wir analysieren diesen Prozess.

Wenn Sie URL eingeben, erkennt der Browser diese URL Wie lautet die entsprechende IP? Nur wenn die IP-Adresse bekannt ist, kann sich der Browser darauf vorbereiten, die Anfrage konkret an den angegebenen Server zu senden IP und Portnummer. Der DNS-Parser des Browsers ist für das Parsen der URL in die richtige IP verantwortlich Adresse. Dieser Parsing-Vorgang nimmt Zeit in Anspruch und während dieser Parsing-Zeitspanne kann der Browser nichts vom Server herunterladen. Browser und Betriebssysteme bieten Unterstützung für DNS-Auflösungs-Caching. Nach Erhalt der IP-Adresse sendet der Browser eine HTTP-Anfrage an den Server. Der Vorgang ist wie folgt folgt:

1. Der Browser fordert den Server auf, eine Verbindung 2

zu öffnen, indem er ein

TCP-Paket sendet. Der Server antwortet auch auf den Browser des Clients, indem er ein Paket sendet und dem Browser mitteilt, dass die Verbindung geöffnet ist.

3. Der Browser sendet eine HTTPGET-Anfrage. Diese Anfrage enthält viele Dinge, wie zum Beispiel unser gemeinsames Cookie und andere HeadHeader-Informationen.

Auf diese Weise wird eine Anfrage gesendet.

Nachdem die Anfrage gesendet wurde, ist es Sache des Servers. Das serverseitige Programm sendet das Endergebnis an den Client.

Tatsächlich sind die Dokumente von html das erste, was den Browser erreicht. Die sogenannten Dokumente von html sind reine HTMLDer Code enthält keine Bilder, Skripte, CSS usw. Das heißt, die HTML-Struktur der Seite. Denn was zu diesem Zeitpunkt zurückgegeben wird, ist nur die HTML-Struktur der Seite. Die Zeit, die benötigt wird, um dieses HTML-Dokument an den Browser zu senden, ist sehr kurz und macht im Allgemeinen etwa 10 % der gesamten Antwortzeit aus.

Danach befindet sich das Grundgerüst der Seite im Browser. Der nächste Schritt ist der Prozess der Analyse der Seite durch den Browser, bei dem es sich um eine schrittweise Analyse von oben handelt nach untenHTMLSkelett.

Wenn zu diesem Zeitpunkt das img-Tag im html-Dokument gefunden wird, sendet der Browser eine HTTP-Anfrage an dieses Die URL-Adresse der img-Antwort wird verwendet, um das Bild abzurufen und es dann anzuzeigen. Wenn das HTML-Dokument, Flash viele Bilder enthält, fordert der Browser sie einzeln an und rendert sie dann. Wenn jedes Bild angefordert werden muss, muss dies der Fall sein zuvor durchgeführt Die genannten Schritte: URL analysieren, TCP-Verbindung öffnen usw. Das Öffnen einer Verbindung verbraucht ebenfalls Ressourcen. Genau wie beim Zugriff auf eine Datenbank versuchen wir, so wenige Datenbankverbindungen wie möglich zu öffnen und mehr Verbindungen im Verbindungspool zu verwenden. Aus dem gleichen Grund können auch TCP-Verbindungen wiederverwendet werden. http1.1 schlug das Konzept der dauerhaften Verbindung (persistente Verbindung) vor, was bedeutet, dass dieselbe HTTP -Verbindung mehrere Anforderungen gleichzeitig verarbeiten kann, wodurch TCP-Verbindung.

Wenn das HTML-Gerüst der Seite geladen wird, beginnt der Browser, die Tags auf der Seite zu analysieren , von Beginnen Sie mit der Analyse von oben nach unten.

Das erste ist das Parsen des head-Tags. Wenn festgestellt wird, dass es ein JS-Skript gibt, das in head, dann Der Browser beginnt zu diesem Zeitpunkt mit der Anforderung des Skripts und der gesamte Seitenanalyseprozess stoppt, bis die JS-Anfrage abgeschlossen ist. Anschließend wird die Seite nach unten geparst, beispielsweise durch Parsen des body-Tags. Wenn in body ein img-Tag vorhanden ist, fordert der Browser img an Die Ressourcen, die src entsprechen. Wenn mehrere img-Tags vorhanden sind, analysiert der Browser sie einzeln und die Analyse wartet nicht wie JS. Wird gleichzeitig heruntergeladen.

Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in Lösungen zur Web-Performance-Optimierung. 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ß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)

So verwenden Sie den Nginx-Webserver-Caddy So verwenden Sie den Nginx-Webserver-Caddy May 30, 2023 pm 12:19 PM

Einführung in Caddy Caddy ist ein leistungsstarker und hoch skalierbarer Webserver, der derzeit über 38.000 Sterne auf Github hat. Caddy ist in der Go-Sprache geschrieben und kann für statisches Ressourcen-Hosting und Reverse-Proxy verwendet werden. Caddy verfügt über die folgenden Hauptfunktionen: Im Vergleich zur komplexen Konfiguration von Nginx ist die ursprüngliche Caddyfile-Konfiguration sehr einfach. Sie kann die Konfiguration über die bereitgestellte AdminAPI dynamisch ändern. Sie unterstützt standardmäßig die automatisierte HTTPS-Konfiguration und kann automatisch HTTPS-Zertifikate beantragen und konfigurieren Sie sie; es kann auf Zehntausende von Websites erweitert werden, ohne dass zusätzliche Abhängigkeiten in der Go-Sprache geschrieben werden müssen; die Speichersicherheit ist besser gewährleistet. Zunächst installieren wir es direkt in CentO

Echtzeitschutz vor Gesichtsblockierungsangriffen im Web (basierend auf maschinellem Lernen) Echtzeitschutz vor Gesichtsblockierungsangriffen im Web (basierend auf maschinellem Lernen) Jun 10, 2023 pm 01:03 PM

Gesichtsblockierendes Sperrfeuer bedeutet, dass eine große Anzahl von Sperrfeuern vorbeischwebt, ohne die Person im Video zu blockieren, sodass es aussieht, als würden sie hinter der Person schweben. Maschinelles Lernen erfreut sich seit mehreren Jahren großer Beliebtheit, aber viele Menschen wissen nicht, dass diese Funktionen auch in Browsern ausgeführt werden können. Dieser Artikel stellt den praktischen Optimierungsprozess in Videosperren vor diese Lösung, in der Hoffnung, einige Ideen zu öffnen. mediapipeDemo (https://google.github.io/mediapipe/) demonstriert das Implementierungsprinzip des On-Demand-Uploads mit Gesichtsblockierung. Die Hintergrundberechnung des Videoservers extrahiert den Porträtbereich im Videobildschirm und konvertiert ihn in SVG Speichern, während der Client das Video abspielt. Laden Sie SVG vom Server herunter und kombinieren Sie es mit Barrage, Portrait

Verwendung von Jetty7 für die Webserververarbeitung in der Java-API-Entwicklung Verwendung von Jetty7 für die Webserververarbeitung in der Java-API-Entwicklung Jun 18, 2023 am 10:42 AM

Verwendung von Jetty7 für die Webserververarbeitung in der JavaAPI-Entwicklung Mit der Entwicklung des Internets ist der Webserver zum Kernbestandteil der Anwendungsentwicklung geworden und steht auch im Fokus vieler Unternehmen. Um den wachsenden Geschäftsanforderungen gerecht zu werden, entscheiden sich viele Entwickler für die Verwendung von Jetty für die Webserverentwicklung, und seine Flexibilität und Skalierbarkeit sind weithin anerkannt. In diesem Artikel wird erläutert, wie Sie Jetty7 für die Webentwicklung in der JavaAPI-Entwicklung verwenden.

So implementieren Sie die Formularvalidierung für Webanwendungen mit Golang So implementieren Sie die Formularvalidierung für Webanwendungen mit Golang Jun 24, 2023 am 09:08 AM

Die Formularvalidierung ist ein sehr wichtiger Link bei der Entwicklung von Webanwendungen. Sie kann die Gültigkeit der Daten vor dem Absenden der Formulardaten überprüfen, um Sicherheitslücken und Datenfehler in der Anwendung zu vermeiden. Die Formularvalidierung für Webanwendungen kann einfach mit Golang implementiert werden. In diesem Artikel wird erläutert, wie Sie mit Golang die Formularvalidierung für Webanwendungen implementieren. 1. Grundelemente der Formularvalidierung Bevor wir uns mit der Implementierung der Formularvalidierung befassen, müssen wir die Grundelemente der Formularvalidierung kennen. Formularelemente: Formularelemente sind

So konfigurieren Sie Nginx, um sicherzustellen, dass der FRP-Server und das Web Port 80 gemeinsam nutzen So konfigurieren Sie Nginx, um sicherzustellen, dass der FRP-Server und das Web Port 80 gemeinsam nutzen Jun 03, 2023 am 08:19 AM

Zunächst werden Sie Zweifel haben: Was ist FRP? Einfach ausgedrückt ist frp ein Intranet-Penetrationstool. Nach der Konfiguration des Clients können Sie über den Server auf das Intranet zugreifen. Jetzt hat mein Server Nginx als Website verwendet und es gibt nur einen Port 80. Was soll ich also tun, wenn der FRP-Server auch Port 80 verwenden möchte? Nach der Abfrage kann dies durch die Verwendung des Reverse-Proxys von Nginx erreicht werden. Hinzufügen: frps ist der Server, frpc ist der Client. Schritt 1: Ändern Sie die Konfigurationsdatei nginx.conf auf dem Server und fügen Sie die folgenden Parameter zu http{} in nginx.conf hinzu: server{listen80

Was sind Webstandards? Was sind Webstandards? Oct 18, 2023 pm 05:24 PM

Webstandards sind eine Reihe von Spezifikationen und Richtlinien, die vom W3C und anderen verwandten Organisationen entwickelt wurden. Sie umfassen die Standardisierung von HTML, CSS, JavaScript, DOM, Web-Zugänglichkeit und Leistungsoptimierung , Wartbarkeit und Leistung. Das Ziel von Webstandards besteht darin, die konsistente Anzeige und Interaktion von Webinhalten auf verschiedenen Plattformen, Browsern und Geräten zu ermöglichen und so ein besseres Benutzererlebnis und eine bessere Entwicklungseffizienz zu gewährleisten.

So aktivieren Sie den administrativen Zugriff über die Cockpit-Web-Benutzeroberfläche So aktivieren Sie den administrativen Zugriff über die Cockpit-Web-Benutzeroberfläche Mar 20, 2024 pm 06:56 PM

Cockpit ist eine webbasierte grafische Oberfläche für Linux-Server. Es soll vor allem neuen/erfahrenen Benutzern die Verwaltung von Linux-Servern erleichtern. In diesem Artikel besprechen wir die Cockpit-Zugriffsmodi und wie Sie den Administratorzugriff von CockpitWebUI auf das Cockpit umstellen. Inhaltsthemen: Cockpit-Eingabemodi Ermitteln des aktuellen Cockpit-Zugriffsmodus Aktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Deaktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Fazit Cockpit-Eingabemodi Das Cockpit verfügt über zwei Zugriffsmodi: Eingeschränkter Zugriff: Dies ist die Standardeinstellung für den Cockpit-Zugriffsmodus. In diesem Zugriffsmodus können Sie vom Cockpit aus nicht auf den Webbenutzer zugreifen

So lösen Sie das Problem der versteckten Nginx-Versionsnummer und der WEB-Serverinformationen So lösen Sie das Problem der versteckten Nginx-Versionsnummer und der WEB-Serverinformationen May 21, 2023 am 09:13 AM

Nginx kann nicht nur Versionsinformationen ausblenden, sondern auch benutzerdefinierte Webserverinformationen. Schauen Sie sich die neueste stabile Version von wgethttp an. //nginx.org/ download/nginx-1.14.1.tar.gz2 Entpacken Sie tar-xfnginx-1.14.1.tar.gzcdnginx-1.14.13 Ändern Sie die C-Datei (1) vimsrc/http/ngx_http_header_filter_module.c       #Modify line 49 staticu_charngx_http_

See all articles