Configure PHP desde la fuente y mod_fgcid en CentOS 6, obteniendo el permiso denegado

Configure PHP desde la fuente y mod_fgcid en CentOS 6, obteniendo el permiso denegado

Compilé PHP desde la fuente y lo instalé en/opt/php/5.5.15/

También instalé (con yum) httpdy mod_fcgid.

Estoy intentando configurar un host virtual para ejecutar php de esta manera:

<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>

Recibo este error:

[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/

Lo intenté chmod 777 php-cgiy chown apache:apache php-cgiambos no hicieron ninguna diferencia.

¿Algunas ideas?

Nota: esta configuración funciona bien en Debian

Respuesta1

Entonces resulta que SELinux estaba negando los derechos ejecutivos de httpd en el contenedor php-cgi.

Ver /var/log/audit/audit.log mostró esto.

Ejecutar lo siguiente lo permite:

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

información relacionada