Atualmente, estou tentando separar três aplicativos de um repositório em três, mas mantendo a estrutura do URL, portanto, basicamente, diferentes locais no mesmo domínio precisam ser entregues por aplicativos diferentes.
O que eu estou enfrentando é que um dos aplicativos precisa ser o substituto para URLs inexistentes; portanto, se o primeiro não corresponder e o segundo não, o terceiro deverá lidar com a solicitação
A estrutura que eu tenho é:
/ etc / nginx / sites-enabled / main_site, aqui, além do server_name e dos logs que tenho include /etc/nginx/subsites-enabled/*
, onde tenho 3 arquivos de configuração, um para cada um dos aplicativos.
Cada um dos 3 arquivos de configuração contém um bloco de localização.
Eu tentei lookahead negativo no regex (basicamente tentando codificar os URLs que os outros aplicativos manipulam), mas falhei.
Então, para resumir:
/ e / community devem ser entregues por /etc/nginx/subsites-enabled/example.org/home (alguns scripts perl)
/ news deve ser entregue em /etc/nginx/subsites-enabled/example.org/news (wordpress)
todo o resto deve ser entregue por /etc/nginx/subsites-enabled/example.org/app (aplicativo de bolo)
O bit perl funciona bem. O problema que estou enfrentando é que o aplicativo está assumindo as notícias (provavelmente porque corresponde. *). Tentei várias opções (já estou nisso há 2 dias), mas nenhuma delas resolveu todos os problemas (às vezes ativos estáticos não funcionariam etc.).
Minha configuração é:
/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 / ativado por subsites / 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) para o seu bloco de aplicativos, você deve poder fazer location /
(isso não é o mesmo que location = /
, mas deve corresponder a tudo que ainda não corresponde). c) em alguns casos (principalmente regexes), a ordem importa - você pode combinar os 3 arquivos em um único arquivo com os blocos na ordem correta. Além disso, use try_files em vez de !-e
. Por fim, consulte wiki.nginx.org/HttpCoreModule#location .
@
prefixo) que mapeia para o aplicativo padrão. Você também pode configurar uma página de erro que mapeia um 404 para um local nomeado.