私はWordPressをインストールしています これはApacheサーバー上でも完璧に動作します 私は現在、ホスティング会社の変更(新しい会社はNGinxを提供)と開発スタック(vvvへの移行)の両方を変更中です。
これがインストールの設定方法です:
Wordpressのサブドメインのマルチサイトインストールで、サブフォルダ(/ wp-app /)にコア、別のサブフォルダ(/ wp-app-content /)にwp-content、そしてもちろん私のindex.phpにあります。 、これら2つのフォルダと一緒にルートフォルダに、wp-config.phpと.htaccess。
これが私の問題です :
製品版(Apache)では、管理者は完全に機能し、/ wp-app /フォルダは完全に隠されています。開発版(NGinx)では、adminは部分的に動作しますが、多くのページは404を返し、時にはWPはwp-appでURLを書き換えます。
私が問題の原因だと思うもの :
私のNGinxの書き換えが良くないことはほぼ間違いありません。私はこの問題について言及しているフィードをいくつか見つけましたが、それらは答えがないか、答えが部分的で私のために働いていませんでした。
動作する私の.htaccessファイル :
# 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
部分的に動作する私のnginx.conf :
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; }
}
2つのコメント行は、私が必死で作ったテストです。
これまでに読んで使った資料:
https://codex.wordpress.org/Nginxhttps://rtcamp.com/wordpress-nginx/tutorials/multisite/ その他、このサイトからの2件のフィードを含む、できないこと評判がよくないのでここに投稿してください。
ご助力ありがとうございます。
私は非常によく似たNginxサーバーのセットアップを使用しており、次のようにうまく機能しますが、異なるルートを使用して "Non Secure-http"と "Secure-https"のサーバーブロック構成を個別に分割することを好みます。また、サブディレクトリ構造ごとに、この rtcampの記事 を見て、location / {}
ディレクティブを次のように調整します。
# 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.
#e.g. 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; }
}
..
そしてindex.phpファイルで、パスを/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' );
..
また、SSl証明書が設定されている場合は、WordPressサイトのURLとホームURLが正しいことを確認してください。それはWordPressの下で変更することができます 一般設定 または "example.com"があなたのサイトの正しい場所であるところであなたのwp-config.phpにこれらの2行を置くことによって。注これは必ずしも最良の方法ではありません。値をサイト自体にハードコーディングするだけです。この方法を使用すると、一般設定ページでそれらを編集できなくなります。
define('WP_HOME','https://example.com');
define('WP_SITEURL','https://example.com');