Heim > Betrieb und Instandhaltung > Nginx > So verwenden Sie Nginx für leistungsstarkes statisches Datei-Caching

So verwenden Sie Nginx für leistungsstarkes statisches Datei-Caching

王林
Freigeben: 2023-08-02 16:13:11
Original
1951 Leute haben es durchsucht

So verwenden Sie Nginx für leistungsstarkes statisches Datei-Caching

Nginx ist ein leichter Open-Source-Webserver, der aufgrund seiner hohen Leistung und hohen Parallelitätsfähigkeiten große Aufmerksamkeit und Verwendung gefunden hat. Nginx ist nicht nur ein Webserver, sondern hat auch eine wichtige Funktion: die Bereitstellung einer statischen Datei-Caching-Funktion, die die Zugriffsgeschwindigkeit und Leistung der Website erheblich optimieren kann. In diesem Artikel wird die Verwendung von Nginx für leistungsstarkes statisches Datei-Caching vorgestellt und entsprechende Codebeispiele bereitgestellt.

  1. Konfigurieren Sie Nginx für den Zugriff auf statische Dateien.
    Um die Caching-Funktion für statische Dateien zu aktivieren, müssen Sie zunächst Nginx so konfigurieren, dass Anfragen für statische Dateien identifiziert und verarbeitet werden. Normalerweise umfassen statische Dateien Bilder, CSS-Dateien, JavaScript-Dateien usw. Das Folgende ist ein einfaches Nginx-Konfigurationsbeispiel:
server {
    listen 80;
    server_name example.com;

    root /path/to/static/files;

    location ~* .(jpg|jpeg|png|gif|css|js)$ {
        expires 30d;
        access_log off;
    }
}
Nach dem Login kopieren

In der obigen Konfiguration gibt listen den Port an, den Nginx überwacht, und server_name gibt den Domänennamen des Servers an. root gibt das Stammverzeichnis an, in dem sich die statischen Dateien befinden. Die location-Direktive gibt das passende URL-Muster und die entsprechenden Verarbeitungsparameter an. In der obigen Konfiguration entspricht der reguläre Ausdruck ~* .(jpg|jpeg|png|gif|css|js)$ dem Suffix von jpg, jpeg, png, gif, css oder js. Für Dateien: expires gibt an, dass die Cache-Gültigkeitsdauer 30 Tage beträgt, und access_log off deaktiviert die Zugriffsprotokollierung auf statische Dateien. listen指定了Nginx监听的端口,server_name指定了服务器的域名。root指定了静态文件所在的根目录。location指令指定了匹配的URL模式,以及对应的处理参数。在上面的配置中,通过正则表达式~* .(jpg|jpeg|png|gif|css|js)$匹配了以jpg、jpeg、png、gif、css或js为后缀的文件,expires指定了缓存的有效期为30天,access_log off则禁止了对静态文件的访问日志记录。

  1. 配置Nginx进行静态文件缓存
    为了启用Nginx的静态文件缓存功能,我们可以添加一些额外的配置指令。下面是一个示例:
location ~* .(jpg|jpeg|png|gif|css|js)$ {
    expires 30d;
    access_log off;
    add_header Cache-Control "public";
    add_header Pragma public;
    etag off;
}
Nach dem Login kopieren

在上述示例中,add_header指令添加了两个头部信息,分别是Cache-ControlPragma。这两个头部信息告诉客户端和其他缓存服务器在一定时间内可以使用缓存的副本。etag off禁用了Etag头部信息,因为在某些情况下,Etag可能会导致一些兼容性问题。

  1. 验证静态文件缓存是否生效
    为了验证静态文件缓存是否生效,可以使用浏览器的开发者工具或者命令行工具进行查看。在浏览器的开发者工具中,可以查看HTTP响应头部的Cache-ControlExpires字段,以及响应内容的大小。如果缓存生效,那么在第一次访问静态文件后,再次请求时会看到Cache-ControlExpires的值与上述配置一致,并且响应内容的大小会变得非常小。

另外,可以使用命令行工具如curl来查看HTTP响应头部信息。例如,可以执行以下命令来查看一个图片文件的HTTP响应头部信息:

$ curl -I example.com/path/to/image.jpg
Nach dem Login kopieren

如果缓存生效,那么你会在结果中看到类似下面的行:

Cache-Control: public, max-age=2592000
Expires: Thu, 10 Aug 2023 08:16:50 GMT
Nach dem Login kopieren
  1. 动态更新缓存
    有时候我们可能需要动态地更新缓存,例如当静态文件被修改后。可以通过在文件名或者路径中添加版本号来解决这个问题。例如,假设有一个CSS文件style.css,我们可以将其重命名为style.v1.css
      Konfigurieren Sie Nginx für das statische Datei-Caching
    Um die statische Datei-Caching-Funktion von Nginx zu aktivieren, können wir einige zusätzliche Konfigurationsanweisungen hinzufügen. Hier ist ein Beispiel:

    $ nginx -s reload
    Nach dem Login kopieren

    Im obigen Beispiel fügt die add_header-Direktive zwei Header-Informationen hinzu, nämlich Cache-Control und Pragma-Code >. Diese beiden Header teilen Clients und anderen Caching-Servern mit, dass die zwischengespeicherte Kopie für einen bestimmten Zeitraum verfügbar ist. etag off deaktiviert die Etag-Header-Informationen, da Etag in manchen Fällen Kompatibilitätsprobleme verursachen kann.

      Überprüfen Sie, ob der statische Dateicache wirksam ist
      Um zu überprüfen, ob der statische Dateicache wirksam ist, können Sie zur Überprüfung die Entwicklertools oder Befehlszeilentools des Browsers verwenden. In den Entwicklertools des Browsers können Sie die Felder Cache-Control und Expires des HTTP-Antwortheaders sowie die Größe des Antwortinhalts anzeigen. Wenn der Cache aktiv ist, werden Sie nach dem ersten Zugriff auf die statische Datei feststellen, dass die Werte von Cache-Control und Expires mit den oben genannten übereinstimmen Wenn Sie die Konfiguration erneut anfordern, wird der Antwortinhalt sehr klein.

      🎜🎜Darüber hinaus können Sie Befehlszeilentools wie Curl verwenden, um HTTP-Antwortheaderinformationen anzuzeigen. Sie können beispielsweise den folgenden Befehl ausführen, um die HTTP-Antwort-Header-Informationen einer Bilddatei anzuzeigen: 🎜rrreee🎜Wenn das Caching wirksam wird, werden in den Ergebnissen Zeilen ähnlich der folgenden angezeigt: 🎜rrreee
        🎜Cache mit dynamischer Aktualisierung 🎜 Manchmal müssen wir den Cache möglicherweise dynamisch aktualisieren, beispielsweise wenn eine statische Datei geändert wird. Sie können dieses Problem lösen, indem Sie die Versionsnummer zum Dateinamen oder Pfad hinzufügen. Angenommen, es gibt eine CSS-Datei style.css, können wir sie in style.v1.css umbenennen und die Konfigurationsdatei von Nginx so aktualisieren, dass sie mit dem neuen Dateinamen übereinstimmt. Auf diese Weise müssen Sie bei jeder Änderung der CSS-Datei nur die Versionsnummer im Dateinamen aktualisieren. 🎜🎜🎜Darüber hinaus bietet Nginx auch einen Reload-Befehl zum Neuladen der Konfigurationsdatei, ohne den Server anzuhalten. Sie können beispielsweise den folgenden Befehl ausführen, um die Nginx-Konfigurationsdatei neu zu laden: 🎜rrreee🎜 Auf diese Weise liest Nginx die Konfigurationsdatei erneut und die aktualisierte Konfiguration wird sofort wirksam. 🎜🎜Zusammenfassung🎜Durch die Verwendung von Nginx für das statische Datei-Caching können die Leistung und Zugriffsgeschwindigkeit der Website erheblich verbessert werden. In diesem Artikel stellen wir vor, wie man Nginx konfiguriert, um statischen Dateizugriff und Caching-Funktionen zu ermöglichen, und stellen entsprechende Codebeispiele und Überprüfungsmethoden bereit. Wir hoffen, dass dieser Inhalt Ihnen dabei hilft, die Leistung Ihrer Website zu optimieren. 🎜

    Das obige ist der detaillierte Inhalt vonSo verwenden Sie Nginx für leistungsstarkes statisches Datei-Caching. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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