Heim > Betrieb und Instandhaltung > Nginx > So verwenden Sie Nginx zum Zwischenspeichern statischer Dateien auf dem Server

So verwenden Sie Nginx zum Zwischenspeichern statischer Dateien auf dem Server

WBOY
Freigeben: 2023-05-15 23:37:04
nach vorne
1724 Leute haben es durchsucht

1. Vorteile von Nginx-Caching

So verwenden Sie Nginx zum Zwischenspeichern statischer Dateien auf dem Server

Wie in der Abbildung gezeigt, kann Nginx-Caching den Druck auf den Quellserver bei der Verarbeitung von Anfragen bis zu einem gewissen Grad reduzieren.
Weil viele der statischen Dateien (wie CSS, JS, Bilder) nicht häufig aktualisiert werden. Nginx verwendet Proxy_cache, um Benutzeranfragen in einem lokalen Verzeichnis zwischenzuspeichern. Die nächste gleiche Anfrage kann die Cache-Datei direkt aufrufen, ohne den Server anfordern zu müssen.
Schließlich ist die Verarbeitung io-intensiver Dienste die Stärke von Nginx.

Zweitens, wie man es einrichtet

Zuerst eine Kastanie:

http{
  proxy_connect_timeout 10;
  proxy_read_timeout 180;
  proxy_send_timeout 5;
  proxy_buffer_size 16k;
  proxy_buffers 4 32k;
  proxy_busy_buffers_size 96k;
  proxy_temp_file_write_size 96k;
  proxy_temp_path /tmp/temp_dir;
  proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache_one:100m inactive=1d max_size=10g;
  server {
    listen    80 default_server;
    server_name localhost;
    root /mnt/blog/;
    location / {
    }
    #要缓存文件的后缀,可以在以下设置。
    location ~ .*\.(gif|jpg|png|css|js)(.*) {
        proxy_pass http://ip地址:90;
        proxy_redirect off;
        proxy_set_header host $host;
        proxy_cache cache_one;
        proxy_cache_valid 200 302 24h;
        proxy_cache_valid 301 30d;
        proxy_cache_valid any 5m;
        expires 90d;
        add_header wall "hey!guys!give me a star.";
    }
  }
  # 无nginx缓存的blog端口
  server {
    listen 90;
    server_name localhost;
    root /mnt/blog/;
    location / {
    }
  }
}
Nach dem Login kopieren

Da ich auf einem Server getestet habe, habe ich zwei Ports 80 und 90 verwendet, um die Interaktion zwischen zwei Servern zu simulieren.

Port 80 ist mit dem normalen Domänennamen ()-Zugriff verbunden.
Port 90 ist für die Verarbeitung des Ressourcenzugriffs zuständig, der über Port 80 erfolgt.
Entspricht Port 90 als Quellserver und Port 80 als Nginx-Reverse-Cache-Proxyserver.

Lassen Sie uns als nächstes über die Konfigurationselemente sprechen:

2.1 http-Layer-Einstellungen

 proxy_connect_timeout 10;
  proxy_read_timeout 180;
  proxy_send_timeout 5;
  proxy_buffer_size 16k;
  proxy_buffers 4 32k;
  proxy_busy_buffers_size 96k;
  proxy_temp_file_write_size 96k;
  proxy_temp_path /tmp/temp_dir;
  proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache_one:100m inactive=1d max_size=10g;
Nach dem Login kopieren
  • proxy_connect_timeout Serververbindungszeitlimit

  • proxy_read_timeout Nachdem die Verbindung erfolgreich hergestellt wurde, warten Sie auf die Antwortzeit des Backend-Servers

  • Proxy_send_timeout nach Endserver-Datenrückgabezeit

  • proxy_buffer_size Puffergröße

  • proxy_buffers Legen Sie die Anzahl der Puffer für jede Verbindung auf „Number“ und die Größe jedes Puffers auf „Size“ fest

  • proxy_busy_buffers_size Nach dem Einschalten der gepufferten Antwortfunktion Ohne alle Antworten zu lesen: Wenn der Schreibpuffer eine bestimmte Größe erreicht, sendet Nginx auf jeden Fall eine Antwort an den Client, bis der Puffer kleiner als dieser Wert ist.

  • proxy_temp_file_write_size Legen Sie die Größenbeschränkung für Nginx fest, um jedes Mal Daten in temporäre Dateien zu schreiben.

  • proxy_temp_path Der Speicherpfad der vom Backend-Server empfangenen temporären Dateien.

  • proxy_cache_path Legen Sie den Cache-Pfad und andere Parameter fest. Wenn innerhalb der durch den inaktiven Parameter angegebenen Zeit (derzeit 1 Tag) nicht auf die zwischengespeicherten Daten zugegriffen wird, werden sie aus dem Cache entfernt

    server {
        listen    80 default_server;
        server_name localhost;
        root /mnt/blog/;
        location / {
        }
        #要缓存文件的后缀,可以在以下设置。
        location ~ .*\.(gif|jpg|png|css|js)(.*) {
            proxy_pass http://ip地址:90;
            proxy_redirect off;
            proxy_set_header host $host;
            proxy_cache cache_one;
            proxy_cache_valid 200 302 24h;
            proxy_cache_valid 301 30d;
            proxy_cache_valid any 5m;
            expires 90d;
            add_header wall "hey!guys!give me a star.";
        }
      }
    Nach dem Login kopieren

proxy_pass nginx kann die Ressource im Cache nicht abrufen, die Anfrage nicht an diese Adresse weiterleiten, die neue Ressource abrufen und zwischenspeichern

proxy_redirect Legen Sie den Antwortheader „Standort“ des Backend-Servers und den Ersetzungstext von „ fest. „refresh“-Antwortheader

proxy_set_header ermöglicht das Neudefinieren oder Hinzufügen des an den Backend-Server gesendeten Anforderungsheaders
  • proxy_cache gibt den gemeinsam genutzten Speicher an, der für das Seiten-Caching verwendet wird, entsprechend der von der http-Ebene festgelegten „keys_zone“
  • Proxy_cache_valid-Sets unterschiedliche Cache-Zeiten für unterschiedliche Antwortstatuscodes
  • Cache-Zeit läuft ab
  • Hier richte ich statische Bilder, CSS und JS-Ressourcen für das Caching ein.
  • Wenn der Benutzer den Domänennamen eingibt, wird die Zugriffsadresse von ip:port durch Analyse ermittelt. Der Port ist standardmäßig auf 80 eingestellt. Daher wird die Seitenanforderung vom aktuellen Server abgefangen und verarbeitet.

  • Wenn die statische Ressource, die mit dem oben genannten Dateinamen endet, analysiert wird, wird die statische Ressource aus dem Cache-Bereich abgerufen.

  • Wenn die entsprechende Ressource abgerufen wird, werden die Daten direkt zurückgegeben.

  • Wenn es nicht abgerufen werden kann, wird die Anfrage zur Verarbeitung an die Adresse weitergeleitet, auf die Proxy_pass verweist.


2.2.2 Quellserver

server {
    listen 90;
    server_name localhost;
    root /mnt/blog/;
    location / {
    }
  }
Nach dem Login kopieren

Hier wird die an Port 90 empfangene Anfrage direkt verarbeitet und Ressourcen werden aus dem lokalen Verzeichnis /mnt/blog des Servers abgerufen, um zu antworten.

3. So überprüfen Sie, ob der Cache gültig ist

Aufmerksame Leser sollten bemerken, dass ich im zweiten Absatz eine Easter Egg Add_Header-Wand hinterlassen habe.

add_header wird verwendet, um benutzerdefinierte Informationen im Header festzulegen. Wenn der Cache also gültig ist, enthält der von der statischen Ressource zurückgegebene Header diese Informationen definitiv.

Die Besuchsergebnisse sind wie folgt:

Das obige ist der detaillierte Inhalt vonSo verwenden Sie Nginx zum Zwischenspeichern statischer Dateien auf dem Server. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:yisu.com
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