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

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

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

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

PHP

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

Q&A

解決済

1回答

4062閲覧

php7 & CentOS7 でPHPのエラーログが出力されない

tesopgmh

総合スコア146

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

PHP

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

0グッド

0クリップ

投稿2021/04/14 13:43

PHP 7.4.16 (cli) (built: Mar 2 2021 10:35:17) ( NTS )
CentOS Linux release 7.9.2009 (Core)
Apache/2.4.6 (CentOS)
getenforce Disabled(SELinux無効)

上記環境でPHPのエラーログが出力されません

「phpinfo()」の結果は

DirectiveLocal ValueMaster Value
error_log/tmp/php.log/tmp/php.log
error_reporting3276732767

32767だと分かりにくいですが、php.ini 上のerror_reportingは以下です(全部出し設定)
error_reporting = E_ALL

apache2handler
Apache VersionApache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/7.4.16

「/tmp/php.log」に関しては以下のようにパーミッション設定済み

touch /tmp/php.log chown apache:apache /tmp/php.log chmod 600 /tmp/php.log

(chmodは777でも検証済み)

https://qiita.com/bezeklik/items/8aaf024b495a30bc4e89
上記サイトで

chcon -t httpd_log_t /var/log/php_error.log

が必要だと言及されていますが、SELINUXは切っております
念のため

chcon -t httpd_log_t /tmp/php.log

を実行すると

chcon: ラベルが付けられていないファイル `/tmp/php.log' に部分的なコンテキストを適用できません

となります

この状態で、エラーを意図的に作り出すと

error_hoge();

Fatal error: Uncaught Error: Call to undefined function error_hoge() in /var/www/html/error.php:3 Stack trace: #0 {main} thrown in /var/www/html/error.php on line 3

と画面上にエラーは出ますがエラーログに記録されません

そこで今度はエラーログ関数を使って明示的に書き込みをしてみます

error_log("[". date('Y-m-d H:i:s') . "]". "保存に失敗しました。\n", 3, "/tmp/php.log");

すると

Warning: error_log(/tmp/php.log): failed to open stream: Permission denied in /var/www/html/error.php on line 2

パーミッションエラーであることが分かります

ls -la /tmp

-rwxrwxrwx 1 apache apache 92 4月 14 22:11 php.log

意図した状態にパーミッションはなっているっぽい(chmodは777)

もしかしたらWEBサーバのユーザーがapacheという名前ではない??

cat /etc/passwd

root❌0:0:root:/root:/bin/bash
bin❌1:1:bin:/bin:/sbin/nologin
daemon❌2:2:daemon:/sbin:/sbin/nologin
~省略~
apache❌48:48:Apache:/usr/share/httpd:/sbin/nologin

名前はどう見てもapache

もうお手上げです
なぜログが出力されないのか分かる方お教えいただけると幸いです

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

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

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

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

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

guest

回答1

0

ベストアンサー

CentOS7標準だと、php.iniで/tmpを指した場合
/tmp/systemd-private-httpd.service-xxxxxx/tmp(xxxxは乱数)にリダイレクトされます。

ls -al /tmp|grep httpdとして、それっぽいディレクトリが無いか探してみてください。

投稿2021/04/14 13:54

tanat

総合スコア18727

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

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

tesopgmh

2021/04/14 14:04

ああああ!ドンピシャでありました ありがとうございます!!! これのためにすごい時間損しました これ、誰トク仕様なのですかね(T T)
tanat

2021/04/14 14:09

セキュリティ的な意味合いで実装されている仕様ですね。 /tmpに(パーミッション指定をせずに)直接置くと他のプロセスからもファイルを読めてしまいますが、systemd-private-xxxx/以下は設置したプロセスからしかアクセス出来ない様に保護されます
tanat

2021/04/14 14:09

詳細は systemd privatetmp あたりをキーワードにして調べてみて下さい
tesopgmh

2021/04/14 14:15

ありがとうございます! とても勉強になりました 調べさせていただきます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問