Назад | Перейти на главную страницу

Настройка Apache 2.2 + FastCGI + SuExec + PHP-FPM на Centos 6

Я пытаюсь следить за этим очень подробная инструкция здесь, Я просто перешел с пользователя www-data на пользователя apache и использую / var / www / hosts / sitename / public_html вместо / home / user / public_html

Однако я потратил целый день, пытаясь понять, почему содержимое файла php отображается без правильного анализа. Я просто не могу понять этого. Ниже моя текущая конфигурация:

/etc/httpd/conf.d/fastcgi.conf

User apache
Group apache

LoadModule fastcgi_module modules/mod_fastcgi.so

# dir for IPC socket files
FastCgiIpcDir /var/run/mod_fastcgi

# wrap all fastcgi script calls in suexec
FastCgiWrapper On

# global FastCgiConfig can be overridden by FastCgiServer options in vhost config
FastCgiConfig -idle-timeout 20 -maxClassProcesses 1

# sample PHP config
# see /usr/share/doc/mod_fastcgi-2.4.6 for php-wrapper script
# don't forget to disable mod_php in /etc/httpd/conf.d/php.conf!
#
# to enable privilege separation, add a "SuexecUserGroup" directive
# and chown the php-wrapper script and parent directory accordingly
# see also http://www.brandonturner.net/blog/2009/07/fastcgi_with_php_opcode_cache/
#
FastCgiServer /var/www/www-data/php5-fcgi
#AddType application/x-httpd-php .php

AddHandler php-fcgi .php
Action php-fcgi /fcgi-bin/php5-fcgi

Alias /fcgi-bin/ /var/www/www-data/

#FastCgiExternalServer /usr/lib/cgi-bin/php5-fcgi -socket /tmp/php5-fpm.sock -pass-header Authorization
#DirectoryIndex index.php
#
<Location /fcgi-bin/>
#    Order Deny,Allow
#    Deny from All
#    Allow from env=REDIRECT_STATUS
    SetHandler fcgid-script
    Options +ExecCGI
</Location>

/etc/httpd/conf.d/vhost.conf

<VirtualHost>
                DirectoryIndex index.php index.html index.shtml index.cgi

                SuexecUserGroup www.mysite.com mygroup

                Alias /fcgi-bin/ /var/www/www-data/www.mysite.com/
                DocumentRoot /var/www/hosts/mysite.com/w/w/w/www/

                <Directory /var/www/hosts/mysite.com/w/w/w/www/>
                        Options -Indexes FollowSymLinks                        
                        AllowOverride None
                        Order allow,deny
                        allow from all
                </Directory>
</VirtualHost>

PS: 1. Кроме того, в PHP5.5 мне вообще нужен FPM или он уже включен? 2. Я использую mod_fastcgi, не уверен, что это проблема, и мне следует переключиться на mod_fcgid? Кажется, что в Интернете есть противоречивые записи о том, какая из них лучше. У меня много виртуальных хостов, запущенных на машине, и я надеюсь, что смогу предоставить каждому пользователю собственный opcache.

Во-первых, вы его переборщили.

Вам не нужны suphp + php-fpm, поскольку они в основном делают то же самое.

Если вам нужна многопользовательская среда с несколькими виртуальными хостами, вы должны использовать следующий стек:

apache + mod_fastcgi + php-fpm

php-fpm позволяет вам определять пулы, которые могут работать под другим пользователем с совершенно разными настройками php.

Для этой конфигурации вам нужно будет вернуть apache к его базовой конфигурации:

user apache
group apache

Я предполагаю, что вы будете запускать свои хосты в папке homedirs public_html ваших пользователей.

Вам нужно будет chmod / home /% user% на 755 и изменить группу для public_html на apache

chown %user%:apache /home/%user%/public_html
chomod 755 /home/%user%

Затем вы определите пул php-fpm для пользователя

[%user%]

listen = /var/run/php-fpm/%user%.socket
listen.backlog = -1
listen.allowed_clients = 127.0.0.1
listen.owner = web
listen.group = www
listen.mode = 0666

user = %user%
group = %userg%

#pm.status_path = /fpm-status
pm = ondemand
pm.max_children = 20
#pm.start_servers = 6
#pm.min_spare_servers = 5
#pm.max_spare_servers = 10
pm.max_requests = 500
request_terminate_timeout = 600s
rlimit_files = 131072
rlimit_core = unlimited
catch_workers_output = yes



php_admin_value[error_log] = /home/%user%/fpm-error.log
php_flag[display_errors] = on
php_flag[display_startup_errors] = on
php_admin_flag[log_errors] = on
php_admin_value[memory_limit] = 128M
php_value[session.save_handler] = files
php_value[session.save_path] = /tmp

обратите внимание, что это пример файла, я рекомендую изменить его перед использованием на производственной машине

После установки и настройки mod_fastcgi вам нужно будет добавить специальный обработчик php для каждого пользователя, например

nano /etc/httpd/conf.d/php-fpm.conf

Action fcgi-php-fpm /fcgi-php-fpm virtual
Alias /fcgi-php-fpm /fcgi-php-fpm
FastCgiExternalServer /fcgi-php-fpm -socket /var/run/php-fpm/web.socket -pass-header Authorization -idle-timeout 180

И в вашем файле vhost

<VirtualHost *:80>

 ServerName beforeafter.local
 ServerAlias www.beforeafter.local
 DocumentRoot /home/web/public_html/before
 DirectoryIndex index.htm index.html index.php
 ErrorLog  /home/web/ba.error.log
 CustomLog /home/web/ba.access.log combined
 UseCanonicalName Off

 Options FollowSymlinks +Indexes
 RewriteEngine On

 AddType text/html .php
 AddHandler fcgi-php-fpm .php

 <Directory />
  AllowOverride All
 </Directory>
</VirtualHost>

Ваше имя действия и имя обработчика должны совпадать, чтобы работать.

После этого каждый пользователь запускает php под своим именем.

Я рекомендую отключить все ненужные модули apache, чтобы ускорить его, и отключить SELinux, если вы не разбираетесь в его настройке.