今朝、Debian WebサーバーをWheezyにアップグレードしましたが、他のすべてが正常に行われた後、ApacheはPHPスクリプトを実行する機能を失ったようですが、アップグレード前は実行できました。 。PHPモジュールが有効になっていないかのように、PHPコードのみが表示されます。
私はすべての通常の容疑者をチェックし、PHPモジュールがロードおよびインストールされていることを確認し、/ etc/Apache2/mods-enabled /php5.confに「SetHandlerapplication/x」があることを確認しました。 -httpd-php "オプションセット。ApacheにPHP5をインストールするための最新のドキュメントにも従いましたが、すべてがチェックアウトされているようです。Apacheエラーログにも問題を示すエラーはありません。
見逃したことはありますか?
'apachectl -t -D DUMP_MODULES | grep php'からの出力:
Syntax OK
php5_module (shared)
'www3:/ etc/Apache2#Apache2 -v'からの出力:
Server version: Apache/2.2.22 (Debian)
Server built: Jan 31 2014 18:55:37
/etc/Apache2/mods-enabled/php5.confの内容:
<IfModule libphp5.so>
# <FilesMatch "\.ph(p3?|tml)$">
# </FilesMatch>
<FilesMatch "\.php$">
SetHandler application/x-httpd-php
</FilesMatch>
# To re-enable php in user directories comment the following lines
# (from <IfModule ...> to </IfModule>.) Do NOT set it to On as it
# prevents .htaccess files from disabling it.
<IfModule mod_userdir.c>
<Directory /home/*/public_html>
php_admin_value engine Off
</Directory>
</IfModule>
</IfModule>
前回の再起動からの最新のApacheエラーログ:
[Thu Apr 10 15:35:44 2014] [notice] caught SIGTERM, shutting down
[Thu Apr 10 15:35:45 2014] [warn] No JkLogFile defined in httpd.conf. Using default /var/log/Apache2/mod_jk.log
[Thu Apr 10 15:35:45 2014] [warn] No JkShmFile defined in httpd.conf. Using default /var/log/Apache2/jk-runtime-status
[Thu Apr 10 15:35:45 2014] [warn] Init: Name-based SSL virtual hosts only work for clients with TLS server name indication support (RFC 4366)
[Thu Apr 10 15:35:45 2014] [notice] suEXEC mechanism enabled (wrapper: /usr/lib/Apache2/suexec)
[Thu Apr 10 15:35:45 2014] [notice] Digest: generating secret for digest authentication ...
[Thu Apr 10 15:35:45 2014] [notice] Digest: done
[Thu Apr 10 15:35:45 2014] [warn] No JkLogFile defined in httpd.conf. Using default /var/log/Apache2/mod_jk.log
[Thu Apr 10 15:35:45 2014] [warn] No JkShmFile defined in httpd.conf. Using default /var/log/Apache2/jk-runtime-status
[Thu Apr 10 15:35:45 2014] [warn] Init: Name-based SSL virtual hosts only work for clients with TLS server name indication support (RFC 4366)
[Thu Apr 10 15:35:45 2014] [notice] Apache/2.2.22 (Debian) DAV/2 SVN/1.6.17 mod_fcgid/2.3.6 mod_jk/1.2.37 PHP/5.4.4-14+deb7u8 mod_ssl/2.2.22 OpenSSL/1.0.1e mod_Perl/2.0.7 Perl/v5.14.2 configured -- resuming normal operations
これは、Apacheモジュールの1つに問題があることがわかりました。それらのほとんどを無効にすることで問題が解決し、他のすべてが機能するまでそれらを追加し始めました。
次のコマンドを実行してみてください。
Sudo apt-get purge libapache2-mod-php5
Sudo apt-get install libapache2-mod-php5
Sudo a2enmod php5
Sudo service Apache2 restart
これにより、Apacheがmod_phpを実行できるようにするために必要なすべてのパッケージが再インストールされます。
また、ファイルphp5.confがディレクトリ/ etc/Apache2/mods-enabledにあることを確認することもできます。そうであれば、次のように表示されます。
LoadModule php5_module /usr/lib/Apache2/modules/libphp5.so
php5-suhosin
はwheezyでは使用できなくなりましたが、パッケージをパージしない限り、その.ini
ファイルは/etc/php5/conf.d/
に残っているため、PHP=は実行できません。
参照: https://www.debian.org/releases/stable/i386/release-notes/ch-upgrading.html#idp83664