CentOS 6 でソースから PHP と mod_fgcid をセットアップすると、権限が拒否される

CentOS 6 でソースから PHP と mod_fgcid をセットアップすると、権限が拒否される

PHPをソースからコンパイルしてインストールしました/opt/php/5.5.15/

yumまた、 ( 付き)httpd、 、もインストールしましたmod_fcgid

次のように PHP を実行するように仮想ホストを設定しようとしています:

<VirtualHost *:80>
    ServerAdmin [email protected]
    DocumentRoot /var/www/my-site.example.com/site/public
    ServerName my-site.example.com
    ErrorLog /var/www/my-site.example.com/logs/my-site.example.com-error_log
    CustomLog /var/www/my-site.example.com/logs/my-site.example.com-access_log common
    <Directory /var/www/my-site.example.com/site/public>
        Options +indexes
        AllowOverride all
        Order allow,deny
        Allow from all
        Action application/x-httpd-php /php-5.5.15-bin/php-cgi
    </Directory>
</VirtualHost>

<IfModule mod_fcgid.c>
    IdleTimeout 3600
    ProcessLifeTime 7200
    MaxProcessCount 64
    DefaultMaxClassProcessCount 8
    IPCConnectTimeout 300
    IPCCommTimeout 7200
    BusyTimeout 300

    <FilesMatch ".+\.ph(p[345]?|t|tml)$">
        SetHandler application/x-httpd-php
    </FilesMatch>

    ScriptAlias /php-5.5.15-bin/ /opt/php/5.5.15/bin/

    <Directory "/opt/php">
        AllowOverride None
        Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
        Order allow,deny
        Allow from all
    </Directory>
</IfModule>

次のエラーが発生します:

[Thu Aug 14 17:36:20 2014] [error] [client 127.0.0.1] (13)Permission denied: exec of '/opt/php/5.5.15/bin/php-cgi' failed, referer: http://my-site.example.com:10080/
[Thu Aug 14 17:36:20 2014] [error] [client 127.0.0.1] Premature end of script headers: php-cgi, referer: http://my-site.example.com:10080/

chmod 777 php-cgiと を試しましたがchown apache:apache php-cgi、どちらも違いはありませんでした。

何か案は?

注: この設定はDebianでも問題なく動作します

答え1

つまり、SELinux が php-cgi bin 上の httpd 実行権限を拒否していたことが判明しました。

/var/log/audit/audit.log を表示すると、これが示されました。

以下を実行すると許可されます:

sudo chcon -t httpd_sys_script_exec_t /opt/php/5.5.15/bin/php-cgi

関連情報