Heim >Betrieb und Instandhaltung >Nginx >Beispielanalyse der Nginx-Grundfunktion

Beispielanalyse der Nginx-Grundfunktion

王林
王林nach vorne
2023-05-11 23:31:041484Durchsuche

1. Statischer http-Server

Zuallererst ist Nginx ein http-Server, der dem Client statische Dateien (wie HTML und Bilder) über das http-Protokoll 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. Der Client fordert Nginx an und gibt das Ergebnis dann an den Client zurück , Nginx ist das Gegenteil des Proxyservers.

Beispielanalyse der Nginx-Grundfunktion

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?

Schauen Sie weiter nach unten. Der Lastausgleich, der virtuelle Host usw. basieren alle auf dem Reverse-Proxy. Natürlich sind dies nicht nur die Funktionen des Reverse-Proxy.

3. Lastausgleich

Wenn der Website-Verkehr sehr groß ist, verdient der Webmaster gerne Geld, steckt aber gleichzeitig auch in Schwierigkeiten. Da die Website immer langsamer wird, reicht ein Server nicht mehr aus.

Die gleiche Anwendung wird also 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. Nginx kann einen Lastausgleich über einen Reverse-Proxy erreichen.

Beispielanalyse der Nginx-Grundfunktion

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;

  }

}

Die obige Konfiguration weist die Anforderungsabfrage dem Anwendungsserver zu, d. h. mehrere Anforderungen eines Clients können von mehreren verschiedenen Servern verarbeitet werden. Sie können IP-Hash verwenden, um Anfragen einem festen Server zur Verarbeitung auf der Grundlage des Hash-Werts der IP-Adresse des Clients zuzuweisen.

Konfiguration:

upstream myapp {

  ip_hash; # 根据客户端ip地址hash值将请求分配给固定的一个服务器处理

  server 192.168.20.1:8080;

  server 192.168.20.2:8080;

}

server {

  listen 80;

  location / {

    proxy_pass http://myapp;

  }

}

Außerdem kann die Hardwarekonfiguration des Servers gut oder schlecht sein. Wenn Sie die meisten Anfragen guten Servern und eine kleine Anzahl von Anfragen schlechten Servern zuordnen möchten, können Sie dies über die Gewichtung steuern.

Konfiguration:

upstream myapp {

  server 192.168.20.1:8080 weight=3; # 该服务器处理3/4请求

  server 192.168.20.2:8080; # weight默认为1,该服务器处理1/4请求

}

server {

  listen 80;

  location / {

    proxy_pass http://myapp;

  }

}

4. Virtueller Host

Einige Websites haben eine große Anzahl von Besuchen und erfordern 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 den Servern 8080 bzw. 8081. Der Client greift über verschiedene Domänennamen zu und kann den Proxy entsprechend dem Servernamen umkehren.

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 Personen herausfiltern, die bestimmte Domänennamen in böswilliger Absicht auf Ihren Hostserver verweisen.

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 von 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:

Beispielanalyse der Nginx-Grundfunktion

Das obige ist der detaillierte Inhalt vonBeispielanalyse der Nginx-Grundfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen