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

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

ただいまの
回答率

91.25%

  • PHP

    15767questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • nginx

    645questions

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

  • Webサーバー

    343questions

    Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

nginxでAccess denied.が返ってくる

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 78

FUGAMARU-MCPE

score 16

Raspbian Stretch Liteでnginxを用いたWebサーバー環境を構築して、WordPressをそこに引越ししようとセッティングしていて、WordPressのファイル諸々をnginxの設定ファイルで設定しているルートディレクトリに持ってきて、早速ブラウザーからアクセスしてみたのですが、「Access denied.」と表示されるだけで困っています。
nginxのエラーログを見てみたところ、

2017/12/26 10:57:13 [error] 4548#4548: *7 FastCGI sent in stderr: "PHP message: PHP Warning:  Unknown: failed to open stream: Permission denied in Unknown on line 0
Unable to open primary script: /home/fugamaru/nginx/index.php (Permission denied)" while reading response header from upstream, client: 192.168.1.11, server: _, request: "GET / HTTP/1.1", upstream: "fastcgi://unix:/run/php/php7.0-fpm.sock:", host: "192.168.1.13"


このように表示されていました。Permission deniedということだったので、ルートディレクトリのアクセス権を777にしてみたのですが、変わりませんでした。
ルートディレクトリ(WordPressと同じディレクトリ)にphpinfoを表示するPHPファイルを置いてみたのですが、それは普通に見れました。

どなたか解決法を教えていただけないでしょうか。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

0

たぶん、php-fpmNginxを組み合たせているのだと思います。ふつう/home/ユーザー名はパーミッション750700なので、Nginxからは見えません。ドキュメントルートを別のディレクトリに変更してください。

例えば、下記のようにしてNginxのドキュメントルートの変更を検討してください。
※下記fugamaru:ログインユーザーのグループ名とする

#新しいドキュメントルート作成
sudo mkdir /home/webapp
sudo chown nginx:fugamaru /home/webapp
sudo chmod 775 /home/webapp

cd /home/webapp

#必要なWordPressなどすべて移動
mv /home/fugamaru/nginx ./

#オーナーを変更
sudo chown -R nginx:fugamaru ./nginx
ls -alF ./

上記で解決できない場合は、Nginxの設定を確認してみてはいかがでしょうか?
下記では似たような構成でエラーが出てます。
https://qiita.com/jshimazu/items/01f6abc2c3f3e1667d45

また、fastcgi_paramなどの設定を正しく設定します。
https://qiita.com/kotarella1110/items/f1ad0bb40b84567cea66

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/12/26 21:17

    回答ありがとうございます。
    chmodに-Rオプションを付けて一括でパーミションを変更したらアクセスできるようになりましたが、まだ読み込めないファイルがいくつかあって、例えばwp-login.phpでは、laod-styles.phpが403エラーで読み込まれません。
    また別の原因なのでしょうか?

    キャンセル

  • 2017/12/26 21:38

    > chmodに-Rオプションを付けて一括でパーミションを変更したらアクセスできるようになりました

    すみません、これは具体的にどこのパーミッションをどのように変更したのでしょうか? 文章が端的過ぎてわかりません。質問に対する質問返しはできるだけしたくないので、もう少し長くてもいいのできちんと教えてほしいです。

    パーミッションを変更したらアクセスできたということは、Nginxのオーナーとドキュメントルートのオーナー(所有者)がマッチしてないからだと思います。 Nginxオーナーとドキュメントルートのオナーは同じでしょうか?

    キャンセル

  • 2017/12/26 22:03

    申し訳ありません。/home/fugamaru/nginxを一括変更しました。
    回答された通りに新しいディレクトリーを作ってルートディレクトリーもそこに設定し直したのですが、結果変わらずでした。
    現在Nginxはwww-dataというユーザーが動かしているようです。/etc/nginx/nginx.confの最初にuser www-dataと書いてあったのでそうだと思うのですが。
    新しく作ったディレクトリーに関してもchown www-dataでwww-dataに設定してみたのですが、変わりませんでした。

    キャンセル

  • 2017/12/26 22:46

    今思ったのですが、WordPressのURLが、Aレコードで家の回線に向けている独自ドメインになっているので、そのせいで、家の回線から家の回線にアクセスしようとしてファイル諸々が取得できないのですかね?

    キャンセル

  • 2017/12/27 00:10

    Nginxのオーナーが「www-data」なら下記のようにしてみてください。回答にも書いたようにドキュメントルートは、ログインユーザーのディレクトリではなく他のディレクトリにします。SSHアクセスする場合はセキュリティ上よろしくないので。
    ----
    sudo chown -R www-data ドキュメントルートのパス

    ログインユーザーでも書き込み権限が欲しい場合は下記のようにします。
    ----
    sudo chown -R :グループ名 ドキュメントルートのパス
    find ドキュメントルートのパス -type d | xargs sudo chmod 775
    find ドキュメントルートのパス -type f | xargs -n 100 sudo chmod 664

    あとは、NginxやPHPのエラーログを見て確認していきます。外部アクセスなのかローカルアクセスなかはNginxの設定に依存しますが、普通は関係ありません。

    キャンセル

  • 2017/12/27 00:19

    回答ありがとうございます。
    回答していただいたコマンドを先程実行した後結果が変わらなかったので改めてコメントさせていただきました。わかりにくくて申し訳ありません。
    それで、今やっと解決に至りました。原因はやはりWordPressに自分の回線宛のドメインが指定されているのが原因でした。スマホの回線(外部ネットワーク)からアクセスしてみたところ、見事に表示されました。

    キャンセル

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

ただいまの回答率

91.25%

関連した質問

同じタグがついた質問を見る

  • PHP

    15767questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • nginx

    645questions

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

  • Webサーバー

    343questions

    Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。