NGinx + WordPress Subdomínio Multi com núcleo no subdiretório

Eu tenho uma instalação do WordPress que funciona perfeitamente em um servidor Apache . Estou atualmente no processo de mudar minha empresa de hospedagem (a nova oferta NGinx) e minha pilha de desenvolvimento (movendo para vvv).

Veja como a instalação está configurada:

É uma instalação multi-site de sub-domínio WordPress, com núcleo em uma sub-pasta (/ wp-app /), conteúdo wp em outra subpasta (/ wp-app-content /) e, claro, meu index.php , wp-config.php e .htaccess na pasta raiz, juntamente com essas 2 pastas.

Aqui está o meu problema :

Na versão de produção (apache), o administrador funciona perfeitamente e a / wp-app / pasta está completamente oculta. Na versão de dev (NGinx), o administrador funciona parcialmente, mas muitas páginas retornam um 404 e às vezes WP reescreva a url com wp-app.

O que eu acho é a fonte do problema :

Tenho quase certeza de que minhas reescritas NGinx não são boas. Eu encontrei vários feeds mencionando o problema, mas eles não foram respondidos ou a resposta foi parcial e não estava funcionando para mim.

Meu arquivo .htaccess que funciona :

# BEGIN WordPress RewriteEngine On RewriteBase / RewriteRule ^index\.php$ - [L] # add a trailing slash to /wp-admin RewriteRule ^wp-admin$ wp-admin/ [R=301,L] RewriteCond %{REQUEST_FILENAME} -f [OR] RewriteCond %{REQUEST_FILENAME} -d RewriteRule ^ - [L] RewriteRule ^(wp-(content|admin|includes).*) wp-app/$1 [L] RewriteRule ^(.*\.php)$ wp-app/$1 [L] RewriteRule . index.php [L] # END WordPress 

Meu nginx.conf que funciona parcialmente :

 server { listen 80; listen 443 ssl; server_name guillaumemolter.dv *.guillaumemolter.dv root /srv/www/guillaumemolter/htdocs; index index.php; if (!-e $request_filename) { rewrite /wp-admin$ $scheme://$host$uri/ last; rewrite ^/(wp-.*.php)$ /wp-app/$1 last; rewrite ^/(wp-(content|admin|includes).*) /wp-app/$1 last; } location / { #try_files $uri $uri/ /wp-app/index.php?$args ; try_files $uri $uri/ /index.php?$args ; } location ~ \.php$ { #try_files /wp-app/$uri =404; try_files $uri =404; include fastcgi_params; fastcgi_pass 127.0.0.1:9000; } location ~* ^.+\.(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|rss|atom|jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid|midi|wav|bmp|rtf)$ { access_log off; log_not_found off; expires max; } location = /robots.txt { access_log off; log_not_found off; } location ~ /\. { deny all; access_log off; log_not_found off; } } 

As 2 linhas comentadas são testes que fiz do desespero …

Recursos que li e usei até agora:

https://codex.wordpress.org/Nginx https://rtcamp.com/wordpress-nginx/tutorials/multisite/ E outros, incluindo 2 feeds deste site, que não posso postar aqui porque não tenho suficiente reputação.

Muito obrigado pela sua ajuda.

Solutions Collecting From Web of "NGinx + WordPress Subdomínio Multi com núcleo no subdiretório"

Eu uso um servidor Nginx muito semelhante ao configurado e o seguinte funciona ótimo para mim, no entanto, prefiro seguir uma rota diferente e dividir a configuração de blocos do servidor para “Non Secure – http” e “Secure – https” individualmente. Além disso, de acordo com sua estrutura de subdiretório, você gostaria de dar uma olhada neste artigo rtcamp para ajustar sua diretriz location / {} seguinte maneira:

 # HTTPS Secure Server # server { listen 443 default_server ssl; ssl on; ssl_certificate /path/to/ssl/certificate.crt; ssl_certificate_key /path/to/ssl/certificate.key; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; # Nginx 1.6 PCI compliance ssl directives, the first one is stronger but slower #It should be preferred when saving credit card and/or sensible information is needed. #eg If redirecting to payment gateways providers such as PayPal is all you need, them it can be safely disabled here. # ssl_ciphers HIGH:!aNULL:!MD5; ssl_ciphers HIGH:!aNULL:!MD5:!kEDH; ssl_prefer_server_ciphers on; root /srv/www/guillaumemolter/htdocs; index index.php; server_name guillaumemolter.dv *.guillaumemolter.dv; location / { try_files $uri $uri/ /wp-app/index.php?q=$uri&$args; } } location ~ \.php$ { try_files $uri = 404; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } # Alternatively Pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 #location ~ \.php$ { #try_files $uri =404; #fastcgi_split_path_info ^(.+\.php)(/.+)$; #fastcgi_pass unix:/var/run/php5-fpm.sock; #fastcgi_index index.php; # #include fastcgi_params; #} location ~* \.(jpg|jpeg|gif|png|bmp|ico|pdf|flv|swf|exe|html|htm|txt|css|js) { add_header Cache-Control public; add_header Cache-Control must-revalidate; expires 7d; access_log off; } } 

 server { listen 80 default_server; server_name guillaumemolter.dv *.guillaumemolter.dv root /srv/www/guillaumemolter/htdocs; index index.php; # Simple redirect - Force non SSL site to redirect traffic to SSL return 301 https://guillaumemolter.dv$request_uri; return 301 https://guillaumemolter.dv$request_uri; if (!-e $request_filename) { rewrite /wp-admin$ $scheme://$host$uri/ permanent; rewrite ^/wp-app(/[^/]+)?(/wp-.*) /wp-app$2 last; rewrite ^/wp-app(/[^/]+)?(/.*\.php)$ /wp-app$2 last; } location / { try_files $uri $uri/ /wp-app/index.php?$args ; } location ~ \.php$ { try_files $uri = 404; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } # Alternatively Pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 #location ~ \.php$ { #try_files $uri =404; #fastcgi_split_path_info ^(.+\.php)(/.+)$; #fastcgi_pass unix:/var/run/php5-fpm.sock; #fastcgi_index index.php; # #include fastcgi_params; #} location ~* ^.+\.(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|rss|atom|jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid|midi|wav|bmp|rtf)$ { access_log off; log_not_found off; expires max; } location = /robots.txt { access_log off; log_not_found off; } location ~ /\. { deny all; access_log off; log_not_found off; } } 

E no seu arquivo index.php, altere o caminho para /wp-app/wp-blog-header.php

 < ?php /** * Front to the WordPress application. This file doesn't do anything, but loads * wp-blog-header.php which does and tells WordPress to load the theme. * * @package WordPress */ /** * Tells WordPress to load the WordPress theme and output it. * * @var bool */ define('WP_USE_THEMES', true); /** Loads the WordPress Environment and Template */ require( dirname( __FILE__ ) . '/wp-app/wp-blog-header.php' ); 

...

Além disso, se um certificado SSl estiver configurado, verifique se o URL do site do WordPress e o URL inicial estão corretos. Ele pode ser alterado em Configurações Gerais do WordPress ou colocando essas duas linhas em seu wp-config.php, onde "example.com" é a localização correta do seu site. Nota Esta não é necessariamente a melhor correção, é apenas codificar os valores no próprio site. Você não poderá editá-los mais na página Configurações Gerais ao usar este método.

 define('WP_HOME','https://example.com'); define('WP_SITEURL','https://example.com');