Auf meinem aktuellen Load Balancer habe ich eine Weiterleitung zu meinem Cluster wie folgt eingerichtet:
upstream myapp1 {
server 192.168.0.20; #RP1
}
server {
listen 80;
location / {
proxy_pass http://myapp1;
proxy_set_header Host $host;
}
}
Was gut funktioniert.
Aber ich habe ein Verzeichnis innerhalb meines Webservers, das eine Menge "Stress" hinter sich hatwww.example.com/local/
Ich habe mich gefragt, ob es eine Methode gibt, um zum Load Balancer (dem leistungsstärksten und aktuellsten Server) umzuleiten, 192.168.1.10
sodass der gesamte Datenverkehr in das lokale Verzeichnis geleitet wird /var/www/local/
. upstream myapp1
Alle anderen Verzeichnisse werden dabei umgeleitet.
Ich habe Folgendes versucht:
Okay, also das Verzeichnis, in dem ich verwendet werden möchte, 192.168.1.10
ist wwww.example.com/local
und auf dem Server ( 192.168.1.10
) befindet es sich. /local
Ich habe diesem Verzeichnis die Berechtigungen wie folgt gegeben:
sudo chown -R www-data:www-data /local
Ich habe dann folgendes in das /etc/nginx/sites-available/default
Feld eingefügt 192.168.1.10
:
upstream myapp1 {
server 192.168.0.20; #RP1
}
server {
listen 80;
location / {
proxy_pass http://myapp1;
proxy_set_header Host $host;
}
location /local/ {
root /local;
index index.php index.html index.htm;
}
server_name 192.168.1.10;
error_page 404 /404.html;
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
location @extensionless-php {
rewrite ^(.*)$ $1.php last;
}
}
Aber es funktioniert nicht, ich bekomme das Fehlerprotokoll
*1 "/local/local/index.php" wurde nicht gefunden (2: Keine solche Datei oder kein solches Verzeichnis)`
Warum wird das Verzeichnis durchsucht /local/local/
? Außerdem habe ich diese Datei und das Verzeichnis jetzt zu Testzwecken hinzugefügt und erhalte das Fehlerprotokoll
widersprüchlicher Servername "192.168.1.10" auf 0.0.0.0:80, ignoriert
Okay, jetzt habe ich das geklärt, indem ich andere Dateien in entfernt habe /etc/nginx/sites-enabled/
.
Jetzt bekomme ich nur eine 404-Seite, wenn ich darauf zugreife www.example.com/local/
und keine Fehlerprotokolle
Antwort1
Sie können mehrerelocation
Anweisungen, die die Anforderungen unterschiedlich behandeln:
upstream myapp1 {
server 192.168.0.20; #RP1
}
upstream myapp2 {
server 192.168.0.10; # some other machine?
}
server {
listen 80;
# server requests to myapp1 if there is no more specific match
location / {
proxy_pass http://myapp1;
proxy_set_header Host $host;
}
# serve requests to this path from a different host
location /foo/ {
proxy_pass http://myapp2;
proxy_set_header Host $host;
}
# serve requests to this path from the local disk
location /this-server/ {
root /var/www;
}
}