Obecnie próbuję rozdzielić 3 aplikacje z jednego repozytorium na 3, ale zachowując strukturę adresu URL, więc zasadniczo różne lokalizacje w tej samej domenie muszą być dostarczane przez różne aplikacje.
Mam problem z tym, że jedna z aplikacji musi być rezerwą dla nieistniejących adresów URL, więc jeśli pierwsza nie pasuje, a druga nie, to trzecia powinna obsłużyć żądanie
Struktura, którą mam to:
/ etc / nginx / sites-enabled / main_site, tutaj oprócz nazwy serwera i dzienników include /etc/nginx/subsites-enabled/*, w których mam 3 pliki konfiguracyjne, po jednym dla każdej aplikacji.
Każdy z 3 plików konfiguracyjnych zawiera blok lokalizacji.
Próbowałem negatywnego lookahead w wyrażeniu regularnym (w zasadzie próbuję zakodować adresy URL obsługiwane przez inne aplikacje), ale nie powiodło się.
Podsumowując:
/ i / community powinno być dostarczone przez /etc/nginx/subsites-enabled/example.org/home (kilka skryptów perla)
/ news powinien być dostarczony przez /etc/nginx/subsites-enabled/example.org/news (wordpress)
wszystko inne powinno być dostarczone przez /etc/nginx/subsites-enabled/example.org/app (aplikacja do ciastek)
Bit Perla działa dobrze. Problem, który mam, polega na tym, że aplikacja przejmuje wiadomości (prawdopodobnie dlatego, że pasuje. *), Próbowałem różnych opcji (byłem przy tym przez 2 dni), ale żadna z nich nie rozwiązała wszystkich problemów (czasami zasoby statyczne nie działałyby itp.).
Moja konfiguracja to:
/etc/nginx/sites-enabled/example.org:
server {
listen 80;
server_name example.org;
error_log /var/log/nginx/example.org.log;
include /etc/nginx/subsites-enabled/example.org/*;
}
/etc/nginx/subsites-enabled/example.org/home:
location = / {
rewrite ^.*$ /index.pl last;
}
location ~* /community(.*) {
rewrite ^.*$ /index.pl last;
}
location ~ \.pl {
root /var/www/vhosts/home;
access_log /var/log/nginx/home/access.log;
error_log /var/log/nginx/home/error.log;
include /etc/nginx/fastcgi_params;
fastcgi_index index.pl;
fastcgi_param SCRIPT_FILENAME /var/www/vhosts/home$fastcgi_script_name;
fastcgi_pass unix:/var/run/fcgiwrap.socket;
}
/ etc / ngins / subsites-enabled / news
location /news {
access_log /var/log/nginx/news/access.log;
error_log /var/log/nginx/news/error.log debug;
error_page 404 = /news/index.php;
root /var/www/vhosts/news;
index index.php;
if (!-e $request_filename) {
rewrite ^.*$ /index.php last;
}
location ~ \.php {
include /etc/nginx/fastcgi_params;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/vhosts/news$fastcgi_script_name;
}
}
/ etc / nginx / subsites-enabled / app:
location ~ .* {
access_log /var/log/nginx/app/access.log;
error_log /var/log/nginx/app/error.log;
rewrite_log on;
index index.php;
root /var/www/vhosts/app/app/webroot;
if (-f $request_filename) {
expires 30d;
break;
}
if (!-e $request_filename) {
rewrite ^.*$ /index.php last;
}
location ~ \.php {
include /etc/nginx/fastcgi_params;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/vhosts/app/app/webroot$fastcgi_script_name;
}
}
location ^~ /news. b) w przypadku bloku aplikacji powinieneś być w stanie to zrobić location /(to nie to samo location = /, ale powinieneś dopasować wszystko, co jeszcze nie jest dopasowane. c) w niektórych przypadkach (szczególnie wyrażenia regularne), kolejność ma znaczenie - możesz połączyć 3 pliki do jednego pliku z blokami we właściwej kolejności. Zamiast tego użyj try_files !-e. Na koniec zobacz wiki.nginx.org/HttpCoreModule#location .
@prefiksu), który mapuje na twoją domyślną aplikację. Możesz także skonfigurować stronę_błędu, która odwzorowuje 404 na nazwaną lokalizację.