Heim >Betrieb und Instandhaltung >Nginx >Beispielanalyse zur Einführung in das Nginx-Grundwissen
nginx ist ein leistungsstarker http- und Reverse-Proxy-Server, der für seine hohe Stabilität, seinen umfangreichen Funktionsumfang, Beispielkonfigurationsdateien und seinen geringen Systemressourcenverbrauch bekannt ist.
nginx-Funktionen Verarbeiten Sie statische Dateien, Indexdateien und automatische Indizierung der Deskriptorpufferung offener Dateien. Cachelose Reverse-Proxy-Beschleunigung, einfacher Lastausgleich und Fehlertoleranz. fastcgi, einfacher Lastausgleich und Fehlertoleranz. Modularer Aufbau. Einschließlich Gzipping, Bytebereiche, Chunked-Antworten sowie SSI-Filter und andere Filter. Wenn mehrere auf einer einzelnen Seite vorhandene SSIs von fastcgi oder einem anderen Proxyserver verarbeitet werden, kann diese Verarbeitung parallel ausgeführt werden, ohne aufeinander zu warten. Unterstützt SSL und TLSSN. Hauptanwendungsszenarien 1. Statischer http-Server
Zuallererst ist Nginx ein http-Server, der dem Client über das http-Protokoll statische Dateien (wie HTML, Bilder) auf dem Server anzeigen kann.
Konfiguration:
server { listen 80; # 端口号 location / { root /usr/share/nginx/html; # 静态文件路径 } }
2. Reverse-Proxy-Server
Was ist ein Reverse-Proxy?
Der Client kann über das http-Protokoll direkt auf einen Website-Anwendungsserver zugreifen. Wenn der Website-Administrator in der Mitte einen Nginx hinzufügt, fordert Nginx den Anwendungsserver an und gibt das Ergebnis dann an den Client zurück , Nginx ist das Gegenteil des Proxyservers.
Konfiguration:
server { listen 80; location / { proxy_pass http://192.168.20.1:8080; # 应用服务器http地址 } }
Da auf den Server direkt über http zugegriffen werden kann, warum sollten wir dazwischen einen Reverse-Proxy hinzufügen? Was macht ein Reverse-Proxy? Wenn wir weiter nach unten schauen, werden die folgenden Lastausgleichs- und virtuellen Hosts alle auf Basis des Reverse-Proxys implementiert. Natürlich sind die Funktionen des Reverse-Proxys nicht darauf beschränkt.
3. Lastausgleich
Wenn der Website-Verkehr sehr groß ist, verdient der Webmaster gerne Geld, ist aber gleichzeitig auch in Schwierigkeiten. Da die Website immer langsamer wird, reicht ein Server nicht mehr aus. Daher wird dieselbe Anwendung auf mehreren Servern bereitgestellt und Anfragen einer großen Anzahl von Benutzern werden zur Verarbeitung auf mehrere Computer verteilt. Gleichzeitig besteht der Vorteil darin, dass der Ausfall eines Servers, solange die anderen Server normal laufen, keine Auswirkungen auf die Nutzung durch den Benutzer hat.
Wenn unsere Website einem größeren Upgrade unterzogen wird, ist es für uns unmöglich, alle Server direkt herunterzufahren und dann ein Upgrade durchzuführen. Normalerweise fahren wir einige Server stapelweise herunter, um die Website zu aktualisieren, und weisen sie bei Benutzeranfragen anderen laufenden Maschinen zur Verarbeitung zu. Nachdem die zuvor ausgeschalteten Maschinen aktualisiert wurden, schalten Sie sie wieder ein und schalten Sie dann einige Maschinen stapelweise aus. Wiederholen Sie den obigen Zyklus, bis alle Maschinen endgültig aktualisiert sind. Dies hat keine Auswirkungen auf die Benutzernutzung.
nginx kann einen Lastausgleich über einen Reverse-Proxy erreichen.
Konfiguration:
upstream myapp { server 192.168.20.1:8080; # 应用服务器1 server 192.168.20.2:8080; # 应用服务器2 } server { listen 80; location / { proxy_pass http://myapp; } }
4. Virtueller Host
Die Website hat eine große Anzahl von Besuchen und benötigt einen Lastausgleich. Allerdings sind nicht alle Websites so hervorragend. Einige Websites müssen aufgrund der geringen Anzahl von Besuchen Kosten sparen, indem sie mehrere Websites auf demselben Server bereitstellen.
Wenn beispielsweise zwei Websites www.aaa.com und www.bbb.com auf demselben Server bereitgestellt werden, werden die beiden Domänennamen in dieselbe IP-Adresse aufgelöst, Benutzer können jedoch über die beiden Domänennamen zwei völlig unterschiedliche Websites öffnen . , beeinflussen sich nicht gegenseitig, genau wie der Zugriff auf zwei Server, daher werden sie als zwei virtuelle Hosts bezeichnet.
Konfiguration:
server { listen 80 default_server; server_name _; return 444; # 过滤其他域名的请求,返回444状态码 } server { listen 80; server_name www.aaa.com; # www.aaa.com域名 location / { proxy_pass http://localhost:8080; # 对应端口号8080 } } server { listen 80; server_name www.bbb.com; # www.bbb.com域名 location / { proxy_pass http://localhost:8081; # 对应端口号8081 } }
Öffnen Sie eine Anwendung auf dem Server-Port 8080 bzw. 8081. Der Client greift über verschiedene Domänennamen zu und kann entsprechend dem Servernamen einen Reverse-Proxy zum entsprechenden Anwendungsserver durchführen.
Das Prinzip des virtuellen Hosts wird dadurch realisiert, dass der Host im HTTP-Anforderungsheader mit dem Servernamen übereinstimmt. Interessierte Schüler können das http-Protokoll studieren.
Darüber hinaus kann die server_name-Konfiguration auch jemanden herausfiltern, der bestimmte Domänennamen böswillig auf Ihren Hostserver verweist.
5. fastcgi
nginx selbst unterstützt keine Sprachen wie PHP, kann jedoch über fastcgi Anforderungen an bestimmte Sprachen oder Frameworks (wie PHP, Python, Perl) senden.
server { listen 80; location ~ \.php$ { include fastcgi_params; fastcgi_param script_filename /php文件路径$fastcgi_script_name; # php文件路径 fastcgi_pass 127.0.0.1:9000; # php-fpm地址和端口号 # 另一种方式:fastcgi_pass unix:/var/run/php5-fpm.sock; } }
In der Konfiguration werden Anfragen mit der Endung .php an php-fpm zur Verarbeitung durch fashcgi übergeben. php-fpm ist ein FastCGI-Manager für PHP. Sie können weitere Informationen zu fashcgi lesen, die in diesem Artikel nicht vorgestellt werden.
Was ist der Unterschied zwischen fastcgi_pass und Proxy_pass? Das Bild unten hilft Ihnen beim Verständnis:
Das obige ist der detaillierte Inhalt vonBeispielanalyse zur Einführung in das Nginx-Grundwissen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!