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

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

ただいまの
回答率

89.64%

nginx + PHP-FPM環境で、DocumentRootの変更ができない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 3,584

前提・実現したいこと

nginx + PHP-FPM(Socket通信)の環境で、デフォルト以外の任意のディレクトリをDocumentRootにしてPHPを実行したい。

環境

CentOS(7.4.1708)
nginx(1.12.2)
PHP(7.1.11)
PHP-FPM(7.1.11)

nginxは、公式のStableバージョンをYumで導入
PHP関連は、Remi repositoryからYumで導入

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

デフォルト以外のディレクトリをDocumentRootに指定すると、"File not found."と表示され、PHPが実行されない。

また、nginxのlogには以下のようなものが出力される。
error.log

2017/11/13 12:40:57 [error] 1937#1937: *1 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: *.*.*.*, server: , request: "GET /index.php HTTP/1.1", upstream: "fastcgi://unix:/var/run/php-fpm/php-fpm.sock:", host: "*.*.*.*"


access.log

*.*.*.* - - [13/Nov/2017:12:40:57 +0900] "GET /index.php HTTP/1.1" "/tmp/foo"404 27 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.62 Safari/537.36" "-" "/index.php" "/index.php" "/tmp/foo" "/index.php"

Config

/etc/nginx/nginx.conf

user  nginx;
worker_processes  1;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" "$document_root"'
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for" "$request_uri" "$document_uri" "$document_root" "$fastcgi_script_name"';
    access_log  /var/log/nginx/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
    include /etc/nginx/conf.d/*.conf;
}


/etc/nginx/conf.d/default.conf

server {
    listen       80 default_server;
    root   /tmp/foo;
    location / {
        index  index.php;
    }
location ~ \.php$ {
include        fastcgi_params;
fastcgi_pass   unix:/var/run/php-fpm/php-fpm.sock;
fastcgi_index  index.php;
fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_intercept_errors on;
}
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /tmp/foo;
    }
}


/etc/php-fpm.conf

include=/etc/php-fpm.d/*.conf
[global]
error_log = /var/log/php-fpm/error.log
daemonize = yes


/etc/php-fpm.d/www.conf

[www]
user = nginx
group = nginx
listen.owner = nginx
listen.group = nginx
listen = /var/run/php-fpm/php-fpm.sock
pm = dynamic
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 5
pm.max_spare_servers = 35
slowlog = /var/log/php-fpm/www-slow.log
php_admin_value[error_log] = /var/log/php-fpm/www-error.log
php_admin_flag[log_errors] = on
php_value[session.save_handler] = files
php_value[session.save_path]    = /var/lib/php/session
php_value[soap.wsdl_cache_dir]  = /var/lib/php/wsdlcache


/tmp/foo/index.php

<?php phpinfo(); ?>

DocumentRootのディレクトリ(/tmp/foo)の権限は、"777"に設定されています。

# ll -d /tmp/foo/
drwxrwxrwx 2 nginx nginx 41 11月 10 20:19 /tmp/foo/

試したこと

デフォルトのDocumentRoot(/usr/share/nginx/html)や、それをコピーして作成した"/usr/share/nginx/html2"というPathをDocumentRootにすると、正常にPHPが実行される。
また、/tmp/foo/index.htmlというStatic contentsを作成すると、正しく表示される。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

おそらく、/usr/lib/systemd/system/php-fpm.service で PrivateTmp=true が設定されていて、php-fpm プロセスから OS の /tmp, /var/tmp が見えなくなっているのだと思います。

DocumentRoot を /tmp, /var/tmp 以外にするといいと思います。

PrivateTmp=false にしたいのであれば、以下のように新規に設定ファイルを作成し、/usr/lib/systemd/system/php-fpm.service の設定を上書きします。

[root]# mkdir /etc/systemd/system/php-fpm.service.d
[root]# vi /etc/systemd/system/php-fpm.service.d/privatetmp.conf
    -------- (下記 2行) --------
    [Service]
    PrivateTmp=false
    ----------------------------

[root]# systemctl daemon-reload
[root]# systemctl restart php-fpm

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/11/13 20:29

    ありがとうございます!
    TaichiYanagiyaさんの方法で解消できました。

    キャンセル

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

  • ただいまの回答率 89.64%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

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