nginx ist ein http-Web Der Server kann statische Dateien (HTML, CSS, Bilder) auf dem Server über das HTTP-Protokoll an den Browser-Client zurückgeben.
Zum Beispiel: Wir stellen eine statische Ressource index.html auf dem Server bereit
Index.html auf Linux hochladen /opt /www/test
Ändern Sie nginx.conf und fügen Sie einen Speicherort hinzu, um die /test-Anfrage abzufangen Root-Pfad. Das heißt, der /slash vor /test
location /test { root /opt/www; index index.html; }
Starten Sie Nginx oder laden Sie Nginx neu : http://192.168.253.130/test/
Lastausgleich
Der Lastausgleich kann in Hardware-Lastausgleich unterteilt werden und Software-Lastausgleich
Hardware-Lastausgleich wie F5, Sangfor, Array usw. hat den Vorteil, dass er vom professionellen Team des Herstellers unterstützt wird und eine stabile Leistung aufweist; der Nachteil ist, dass er teuer ist; 🎜🎜#Abfragemethode: Anfragen dem zuordnen Die Back-End-Server werden der Reihe nach behandelt. Dabei wird jeder Back-End-Server ausgewogen behandelt, ohne sich um die tatsächliche Anzahl der Verbindungen zum Server und die aktuelle Systemlast zu kümmern.
http { upstream test{ ##后端实际服务器 nginx在轮询访问以下几台服务器 server 10.100.30.1:8080; server 10.100.30.2:8080; server 10.100.30.3:8080; server 10.100.30.4:8080; } server { ##前端拦截入口 listen 80; server_name www.test.com; location / { proxy_pass http://test; } } }
Gewichtete Abfragemethode: Verschiedene Backend-Server können unterschiedliche Maschinenkonfigurationen und aktuelle Systemlasten haben, daher ist auch ihre Druckfestigkeit unterschiedlich.
Weisen Sie Maschinen mit hoher Konfiguration und geringer Auslastung höhere Gewichtungen zu, damit diese mehr Anfragen bearbeiten können. Weisen Sie Maschinen mit niedriger Konfiguration und hoher Auslastung niedrigere Gewichtungen zu, um deren Systemleistung zu verringern dies gut und verteilt Anfragen sequentiell und gewichtet an das Backend.
http { upstream test{ ##后端实际服务器 nginx在轮询访问以下几台服务器 server 10.100.30.1:8080 weight=1; server 10.100.30.2:8080 weight=3; server 10.100.30.3:8080 weight=1; server 10.100.30.4:8080 weight=1; } server { ##前端拦截入口 listen 80; server_name www.test.com; location / { proxy_pass http://test; } } }
Quelladresse-Hash-Methode: Basierend auf der IP-Adresse des Clients wird ein Wert über die Hash-Funktion berechnet und der Wert wird verwendet, um die Größe der Serverliste zu modulieren. Das Ergebnis ist Kundenservice Die Seriennummer des Servers, auf den der Client zugreifen möchte.
Mit der Quelladress-Hash-Methode für den Lastausgleich wird ein Client mit derselben IP-Adresse jedes Mal demselben Backend-Server für den Zugriff zugeordnet, wenn die Backend-Serverliste unverändert bleibt.
upstream test{ ip_hash; server 10.100.30.1:8080 weight=1; server 10.100.30.2:8080 weight=3; server 10.100.30.3:8080 weight=1; server 10.100.30.4:8080 weight=1; }
Methode der minimalen Anzahl von Verbindungen: Da die Konfiguration des Back-End-Servers unterschiedlich ist, kann die Anforderungsverarbeitung schneller oder langsamer sein. Die Methode der minimalen Anzahl von Verbindungen wählt dynamisch eine davon basierend auf aus Der aktuelle Verbindungsstatus des Back-End-Servers verarbeitet die aktuelle Anforderung, verbessert die Auslastungseffizienz des Back-End-Dienstes so weit wie möglich und verteilt die Verantwortung angemessen auf jeden Server.
upstream test{ least_conn; server 10.100.30.1:8080; server 10.100.30.2:8080; server 10.100.30.3:8080; server 10.100.30.4:8080; }
down: Zeigt das Stoppen eines bestimmten Dienstes an.
upstream test{ server 10.100.30.1:8080 down; server 10.100.30.2:8080; server 10.100.30.3:8080; server 10.100.30.4:8080; }
backup: Gibt den Backup-Server an, solange andere Server normal darauf zugreifen können Wenn nicht darauf zugegriffen werden kann, wird der Sicherungsserver nur verwendet, wenn andere Server ausgefallen sind. Daher wird diese Methode im Allgemeinen verwendet, um den Code zuerst auf dem Sicherungsserver zu aktualisieren und dann den normalen Server zu stoppen Der normale Server ist abgeschlossen, der Backup-Server Der Server befindet sich wieder im Wartezustand und der gesamte Bereitstellungsprozess ermöglicht Benutzern keine Ausfallzeiten.
upstream test{ server 10.100.30.1:8080 backup; server 10.100.30.2:8080 backup; server 10.100.30.3:8080; server 10.100.30.4:8080; }
Statisch und dynamisch Trennung# Nginx-Nutzungsszenarien und Beispiele
Nginx ist ein leistungsstarker, hochparalleler HTTP-Server und Reverse-Proxy-Server, der in einer Vielzahl von Szenarien wie statischen Ressourcenservern, Load Balancern und Reverse verwendet werden kann Proxys, Cache-Server und Webserver.1. Statischer Ressourcenserver
Wenn Nginx als statischer Ressourcenserver verwendet wird, wird Nginx direkt verwendet Gibt die angeforderte Datei zurück und entlastet dadurch den Webserver. Dieses Szenario wird normalerweise verwendet, um statische Dateidownloads oder den Zugriff auf große Dateien wie Videos bereitzustellen.server { listen 80; server_name example.com; location / { root /usr/share/nginx/html; index index.html index.htm; } location /images/ { alias /var/www/images/; } location /downloads/ { alias /var/www/downloads/; } }
upstream backend { server backend1.example.com:8080 weight=3; server backend2.example.com:8080; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
上述配置中,Nginx会将访问根目录(/)的请求转发给后端的Web服务器(backend1.example.com和backend2.example.com),其中backend1.example.com的权重为3,backend2.example.com的权重为1,表示backend1.example.com的处理能力更强。
在转发请求时,Nginx还会设置HTTP头信息中的Host和X-Real-IP字段,从而隐藏Web服务器的真实IP。
在使用Nginx作为负载均衡器时,Nginx会将请求均衡地分发到多个Web服务器上,从而实现高并发、高可用的服务。这种场景通常用于Web应用程序的集群部署、分布式系统的部署等。下面是一个示例Nginx配置:
upstream backend { server backend1.example.com:8080; server backend2.example.com:8080; server backend3.example.com:8080; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
上述配置中,Nginx会将请求均衡地分发到三个Web服务器(backend1.example.com、backend2.example.com和backend3.example.com)上,从而实现负载均衡。
在转发请求时,Nginx还会设置HTTP头信息中的Host和X-Real-IP字段,从而隐藏Web服务器的真实IP。
在使用Nginx作为缓存服务器时,Nginx会缓存Web服务器返回的响应,从而减少对Web服务器的请求。这种场景通常用于提高Web应用程序的性能、降低Web服务器的负载等。下面是一个示例Nginx配置:
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m; server { listen 80; server_name example.com; location / { proxy_cache my_cache; proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
上述配置中,Nginx会将Web服务器返回的响应缓存到/var/cache/nginx/my_cache目录下,并设置缓存有效期为60分钟。在缓存命中时,Nginx会直接返回缓存的响应,从而减少对Web服务器的请求。
总之,Nginx具有很强的可扩展性和灵活性,可以根据不同的需求配置不同的使用场景。以上仅是一些示例,实际应用中还有很多其他的使用场景。
在使用Nginx作为反向代理服务器时,Nginx会将客户端请求转发到后端的Web服务器上,并将后端服务器返回的响应转发给客户端。这种场景通常用于隐藏后端服务器的真实IP、提高Web应用程序的可用性等。下面是一个示例Nginx配置:
server { listen 80; server_name example.com; location / { proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
上述配置中,Nginx会将客户端请求转发到http://backend上,并设置HTTP头信息中的Host和X-Real-IP字段,从而隐藏后端服务器的真实IP。
在使用Nginx作为WebSocket服务器时,Nginx会将客户端请求转发到后端的WebSocket服务器上,并实现WebSocket协议的连接管理。这种场景通常用于实时通信、游戏等应用程序。
下面是一个示例Nginx配置:
map $http_upgrade $connection_upgrade { default upgrade; '' close; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection $connection_upgrade; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
上述配置中,Nginx会将WebSocket请求转发到http://backend上,并设置HTTP头信息中的Upgrade、Connection、Host和X-Real-IP字段,从而实现WebSocket协议的连接管理。
总之,Nginx具有很多的使用场景,可以根据不同的需求配置不同的服务器功能。以上仅是一些示例,实际应用中还有很多其他的使用场景。
Das obige ist der detaillierte Inhalt vonWas sind die Hauptanwendungsszenarien in Nginx?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!