Nginx – minimale Konfiguration

Freigeben: 2023-08-03 15:55:39
nach vorne
1321 Leute haben es durchsucht

Nginx – minimale Konfiguration

Sichere Server sind Server, die nur die erforderliche Anzahl zulassen. Idealerweise würden wir den Server auf Basis eines Minimalsystems aufbauen, indem wir andere Funktionen einzeln aktivieren. Eine minimale Konfiguration hilft auch beim Debuggen. Wenn der Fehler in einem Minimalsystem nicht verfügbar ist, fügen Sie die Funktionalität einzeln hinzu und suchen Sie weiter nach dem Fehler.

Dies ist die Mindestkonfiguration, die zum Ausführen von Nginx erforderlich ist:

# /etc/nginx/nginx.confevents {}         # event context have to be defined to consider config validhttp { server {    listen 80;    server_name  javatpoint.co  www.javatpoint.co  *.javatpoint.co;    return 200 "Hello";  }
Nach dem Login kopieren

Root-, Location- und try_files-Direktiven

Root-Direktive

Root-Direktive wird verwendet, um das Stammverzeichnis von Anforderungen festzulegen, sodass Nginx eingehende Anforderungen dem Dateisystem zuordnen kann Vorgesetzter.

server {  listen 80;  server_name javatpoint.co;  root /var/www/javatpoint.co;}
Nach dem Login kopieren

Es ​​ermöglicht Nginx, Serverinhalte basierend auf der Anfrage zurückzugeben:

javatpoint.co:80/index.html     # returns /var/www/learnfk.com/index.htmljavatpoint.co:80/foo/index.html # returns /var/www/learnfk.com/foo/index.html
Nach dem Login kopieren

Location-Direktive

Die Location-Direktive wird verwendet, um die Konfiguration basierend auf dem angeforderten URI (Uniform Resource Identifier) ​​festzulegen.

Die Syntax lautet:

location [modifier] path
Nach dem Login kopieren

Beispiel:

location /foo {  # ...}
Nach dem Login kopieren

Wenn kein Modifikator angegeben ist, wird der Pfad als Präfix behandelt und alles kann folgen. Das obige Beispiel passt zu:

/foo/fooo/foo123/foo/bar/index.html...
Nach dem Login kopieren

Wir können in einem bestimmten Kontext auch mehrere Standortanweisungen verwenden:

server {  listen 80;  server_name javatpoint.co;  root /var/www/javatpoint.co;  location/{    return 200 "root";  }  location /foo {    return 200 "foo";  }}javatpoint.co:80  /      # => "root"javatpoint.co:80   /foo    # => "foo"javatpoint.co:80   /foo123 # => "foo"javatpoint.co:80   /bar    # => "root"
Nach dem Login kopieren

Nginx stellt auch einige Modifikatoren bereit, die in Verbindung mit der Standortanweisung verwendet werden können.

Durchsuchen Sie das offizielle Backend der chinesischen Linux-Community und antworten Sie auf „Private Küche“, um ein Überraschungsgeschenkpaket zu erhalten.

Modifikator zugewiesene Priorität:

=           - Exact match^~          - Preferential match~ && ~*     - Regex matchno modifier - Prefix match
Nach dem Login kopieren

Zunächst prüft Nginx, ob alle exakten Übereinstimmungen vorliegen. Wenn sie nicht vorhanden ist, wird nach der bevorzugten Option gesucht. Wenn auch diese Übereinstimmung fehlschlägt, werden Übereinstimmungen mit regulären Ausdrücken in der Reihenfolge getestet, in der sie erscheinen. Wenn alles andere fehlschlägt, wird die letzte Präfixübereinstimmung verwendet.

location /match {  return 200 'Prefix match: will match everything that starting with /match';}location ~* /match[0-9] {  return 200 'Case insensitive regex match';}location ~ /MATCH[0-9] {  return 200 'Case sensitive regex match';}location ^~ /match0 {  return 200 'Preferential match';}location = /match {  return 200 'Exact match';}/match     # => 'Exact match'/match0    # => 'Preferential match'/match1    # => 'Case insensitive regex match'/MATCH1    # => 'Case sensitive regex match'/match-abc # => 'Prefix match: matches everything that starting with /match'
Nach dem Login kopieren

try_files-Direktive

Diese Direktive probiert verschiedene Pfade aus und gibt alle gefundenen zurück.

try_files $uri index.html =404;
Nach dem Login kopieren

Also wird /foo.html versuchen, Dateien in der folgenden Reihenfolge zurückzugeben:

$uri(/foo.html);index.html
Nach dem Login kopieren

Wenn nicht gefunden: 404

如果我们在服务器上下文中定义try_files,然后定义查找所有请求的位置,则不会执行try_files。发生这种情况是因为服务器上下文中的try_files定义了其伪位置,该伪位置是可能的最低特定位置。因此,定义location/ 会比我们的伪位置更具体。

server {  try_files $uri /index.html =404;  location/{  }}
Nach dem Login kopieren

因此,我们应该避免在服务器上下文中使用try_files:

server {  location/{    try_files $uri /index.html =404;  }}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonNginx – minimale Konfiguration. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:Linux中文社区
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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!