質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Q&A

解決済

1回答

4185閲覧

nginxを設定したもののサブディレクトリのwordpressが動作してくれない。

Otazoman

総合スコア44

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

0グッド

0クリップ

投稿2018/09/11 08:57

編集2018/09/15 08:15

前提・実現したいこと

既存サイトからの移行で「/hoge/hoge/wp」という様にルートディレクトリ
から2階層下でwordpressのページを動作させ、2階層目のhogeでは静的ページを
運用したいと考えております。

発生している問題・エラーメッセージ

該当のサイトから/hoge/hoge全体をコピーし、wordpressのデータベース
全体についてもコピーしました。静的サイト全体についても無事に
表示はできている状態です。しかしながらwordpressのサイトにアクセス
しようとすると下記の様にPHPのソースがそのまま表示されてしまいます。

色々と試してみましたが八方手ふさがりなのでご助力をお願いいたします。

・サイトのURLイメージ
https://mysite.example.com/hoge/wp」

・画面
イメージ説明

該当のソースコード

/etc/nginx/conf.d/local.conf

config

1upstream phpfpm71{ 2 server unix:/var/run/php/php7.1-fpm.sock; 3} 4 5server { 6 listen 80; # httpへのアクセスをhttpsへリダイレクトする 7 listen [::]:80; 8 server_name 192.168.1.1; 9 if ($http_x_forwarded_proto != https) { 10 return 301 https://$host$request_uri; 11 } 12} 13server { 14 listen 443 ssl; 15 listen [::]:443 ssl; 16 ssl on; 17 server_name 192.168.1.1; 18 root /var/www/html; 19 #root /var/www; 20 index index.html index.htm index.php; 21 auth_basic "closed site"; 22 auth_basic_user_file "/etc/nginx/auth/.htpassword"; 23 24 ssl_stapling on; 25 ssl_stapling_verify on; 26 ssl_session_timeout 5m; 27 ssl_certificate /etc/nginx/ssl/server.crt; 28 ssl_certificate_key /etc/nginx/ssl/server.key; 29 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 30 ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA'; 31 ssl_prefer_server_ciphers on; 32 33 add_header Strict-Transport-Security "max-age=31536000; includeSubdomains" always; 34 35 location ~*/hoge { 36 ssi on; 37 ssi_last_modified on; 38 } 39 location /hoge/wp { 40 root /var/www/html/hoge/wp; 41 try_files $uri $uri/ @wordpress; 42 index index.php index.html index.htm; 43 location ~* /wp-config.php { 44 deny all; 45 } 46 } 47 location ~ .php$ { 48 try_files $uri $uri @wordpress; 49 fastcgi_index index.php; 50 fastcgi_split_path_info ^(.+.php)(.*)$; 51 fastcgi_pass phpfpm71; 52 include fastcgi_params; 53 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 54 } 55 location @wordpress { 56 fastcgi_index index.php; 57 fastcgi_split_path_info ^(.+.php)(.*)$; 58 fastcgi_pass phpfpm71; 59 include fastcgi_params; 60 fastcgi_param SCRIPT_FILENAME $document_root/index.php; 61 } 62}

試したこと

nginx.confはデフォルトのままいじっていません。

「root /var/www/html」の箇所を「/var/www」に変更し
その配下にwordpressを展開した際には正常に動作しました。

補足情報(FW/ツールのバージョンなど)

  • ubuntu18.04.1
  • nginx version: nginx/1.14.0 (Ubuntu)
  • PHP 7.1.20-1
  • PHP-fpm 7.1
  • mysql Ver 15.1 Distrib 10.1.34-MariaDB

nginxのログには以下のような感じで出力されています。

access.log

1XXX.XX.XXX.XX - adm [15/Sep/2018:17:09:47 +0900] "GET /hoge/wp/ HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36 Edge/17.17134"

該当時間帯にerror.log側ではエラーの出力はありませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

CHERRY

2018/09/15 08:06

nginx のログには、何か出ていますか?
guest

回答1

0

自己解決

色々と調べて何とか自己解決できました。

fastcgi_param SCRIPT_FILENAME

がミソだったようです
https://qiita.com/kotarella1110/items/f1ad0bb40b84567cea66

正しく理解できていないかもしれませんが、下記の記述で意図した操作はできました。
体系立てて理解していかないと何とか動いたレベルになってしまうので、書籍を購入して
必死に読み解いていくことにします。

local.conf

1upstream phpfpm71{ 2 server unix:/var/run/php/php7.1-fpm.sock; 3} 4server { 5 listen 80; 6 listen [::]:80; 7 server_name 192.168.1.1; 8 if ($http_x_forwarded_proto != https) { 9 return 301 https://$host$request_uri; 10 } 11} 12server { 13 listen 443 ssl; 14 listen [::]:443 ssl; 15 ssl on; 16 server_name 192.168.1.1; 17 root /var/www/html; 18 index index.html index.htm index.php; 19 auth_basic "closed site"; 20 auth_basic_user_file "/etc/nginx/auth/.htpassword"; 21 22 ssl_stapling on; 23 ssl_stapling_verify on; 24 ssl_session_timeout 5m; 25 ssl_certificate /etc/nginx/ssl/server.crt; 26 ssl_certificate_key /etc/nginx/ssl/server.key; 27 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 28 ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA'; 29 ssl_prefer_server_ciphers on; 30 add_header Strict-Transport-Security "max-age=31536000; includeSubdomains" always; 31 32 location / { 33 ssi on; 34 ssi_last_modified on; 35 try_files $uri $uri/ index.html index.php; 36 } 37 location ~* /wp-config.php { 38 deny all; 39 } 40 location ^~/wp { 41 root /var/www/html/hoge/wp; 42 index index.php index.html index.htm; 43 try_files $uri $uri/ @wordpress; 44 } 45 location ~ .php$ { 46 try_files $uri $uri @wordpress; 47 fastcgi_index index.php; 48 fastcgi_split_path_info ^(.+.php)(.*)$; 49 fastcgi_pass phpfpm71; 50 include fastcgi_params; 51 fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name; 52 } 53 location @wordpress { 54 fastcgi_index index.php; 55 fastcgi_split_path_info ^(.+.php)(.*)$; 56 fastcgi_pass phpfpm71; 57 include fastcgi_params; 58 fastcgi_param SCRIPT_FILENAME $document_root/hoge/wp/index.php; 59 } 60 error_page 404 /404.html; 61 location = /40x.html { 62 } 63 error_page 500 502 503 504 /50x.html; 64 location = /50x.html { 65 } 66}

投稿2018/09/17 09:16

Otazoman

総合スコア44

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問