PHP-FPM — различия между версиями

Материал из K.Wiki
Перейти к: навигация, поиск
(Дополнительные модули)
Строка 165: Строка 165:
 
Для обработки изображений.
 
Для обработки изображений.
 
  # apt-get install php5-gd
 
  # apt-get install php5-gd
 +
 +
=== php5-imagick ===
 +
Для продвинутой обработки изображений.
 +
# apt-get install php5-imagick
  
 
== Ссылки ==
 
== Ссылки ==

Версия 01:45, 13 февраля 2015

Установка

# apt-get install php5-fpm

После установки для устранения уязвимости нужно в файле /etc/php5/fpm/php.ini заменить

;cgi.fix_pathinfo=1

на

cgi.fix_pathinfo = 0

и перезагрузить службу

# service php5-fpm reload

Настройка директорий и пользователей

В этом руководстве считается, что для хранения файлов каждого сайта используется директория /var/www/{имя сайта}/www/. Поэтому нужно обеспечить существование этой директории ({имя сайта} нужно заменить своим значением)

# mkdir /var/www
# mkdir /var/www/{имя сайта}
# mkdir /var/www/{имя сайта}/www
# mkdir /var/www/{имя сайта}/save
# mkdir /var/www/{имя сайта}/tmp

Кроме того, с точки зрения безопасности, полезно, чтобы работа с разными сайтами осуществлялась от имен разных пользователей. Поэтому нужно создать пользователя и предоставить ему права для работы с директорией ({имя пользователя} и {имя сайта} нужно заменить своими значениями)

# useradd {имя пользователя} -G www-data -m -U -s /bin/false
# chown {имя пользователя}:{имя пользователя} -R /var/www/{имя сайта}
# chmod -R a-rwx,u+rwX,g+rX /var/www/{имя сайта}
# adduser www-data {имя пользователя}

Настройка пулов

Пулы используются для описания настроек PHP-FPM. Они позволяют использовать различные параметры PHP для разных сайтов. Настройки пулов хранятся в директории /etc/php5/fpm/pool.d/, по одному файлу *.conf на пул.

Для учета изменений настроек нужно перезагрузить службу

# service php5-fpm reload

Пример настроек ({имя сайта}, {имя пользователя} и {имя группы} нужно заменить своими значениями)

; Имя пула в квадратных скобках.
; Присваивается переменной $pool, которую можно использовать в других директивах.
[{имя сайта}]

; Пользователь и группа, от имени которых работает пул.
user = {имя пользователя}
group = {имя группы}


; Подключение шаблона со стандартными настройками.
include = /etc/php5/fpm/pool.d/templates/default


; Статический режим создания рабочих процессов - число запущенных процессов пула равно максимальному.
;pm = static
; Динамический режим создания рабочих процессов - число запущенных процессов пула зависит от нагрузки.
pm = dynamic

; Максимальное количество процессов пула.
pm.max_children = 7

; Количество рабочих процессов при запуске службы.
pm.start_servers = 3

; Минимальное число простаивающих рабочих процессов.
; Для экономии ресурсов можно приравнять к pm.start_servers.
pm.min_spare_servers = 3

; Максимальное число простаивающих рабочих процессов. 
; От pm.min_spare_servers до pm.max_children.
pm.max_spare_servers = 4

; Количество обработанных запросов, после которого процессы PHP-FPM будут перезагружены.
pm.max_requests = 2000

Шаблоны

Благодаря директиве include в настройки пула можно включать внешние файлы. Шаблоны принято использовать для описания общих настроек. Файлы шаблонов можно сохранять, например, в директорию /etc/php5/fpm/pool.d/templates/.

Например, стандартные настройки пула в файле /etc/php5/fpm/pool.d/templates/default

; Порт и необязательный адрес или имя UNIX-сокета.
; Используется для взаимодействия с WEB-сервером.
;listen = 127.0.0.1:9000
listen = /var/run/php5-fpm_$pool.sock

; Пользователь и группа, которые владеют файлом UNIX-сокета.
; Пользователь, от имени которого работает WEB-сервер должен иметь права на чтение.
listen.owner = www-data
listen.group = www-data

; Права доступа к файлу UNIX-сокета.
;listen.mode = 0660


; Файл лога медленно обрабатываемых запросов.
slowlog = /var/www/$pool/slow.log

; Ограничение по времени, после которого запросы будут считаться медленными.
request_slowlog_timeout = 10s


; Считать /var/www/$pool корневой директорией для скриптов.
; Нужно скорректировать все пути и обеспечить доступ к файлам сокетов и другим необходимым службам внутри этой директории.
;chroot = /var/www/$pool

Изменение глобальных настроек PHP

С помощью директивы php_admin_value можно изменять глобальные настройки PHP для отдельного пула. Например

; Каталог с файлами сайта.
php_admin_value[open_basedir] = /var/www/$pool

; Каталог для размещения временных файлов.
php_admin_value[upload_tmp_dir] = /var/www/$pool/tmp

; Каталог для хранения файлов сессий.
php_admin_value[session.save_path] = /var/www/$pool/save

; Ограничение памяти для выполнения скриптов.
php_admin_value[memory_limit] = 50M

; Настройки ssmtp.
php_admin_value[sendmail_path] = /usr/sbin/ssmtp -t -C/var/www/$pool/ssmtp.conf

Работа с почтой

ssmtp

ssmtp позволяет отправлять почту, используя внешний сервер smtp. Для установки нужно выполнить

# apt-get install ssmtp

Есть возможность сопоставить персональный файл настроек каждому пользователю. Для этого нужно изменить глобальную переменную PHP sendmail_path, например, на /usr/sbin/ssmtp -t -C/var/www/$pool/ssmtp.conf и создать в директории /var/www/{имя сайта} файл ssmtp.conf с таким содержанием (пример для gmail.com; {логин} и {пароль} нужно заменить своими значениями)

root={логин}@gmail.com
mailhub=smtp.gmail.com:587
rewriteDOmain=
hostname=localhost
UseSTARTTLS=YES
FromLineOverride=YES
AuthUser={логин}@gmail.com
AuthPass={пароль}

Для безопасности нужно установить права доступа к файлу:

# chown {имя пользователя}:{имя пользователя} -R /var/www/{имя сайта}/ssmtp.conf
# chmod -R a-rwx,u+rw /var/www/{имя сайта}/ssmtp.conf

PHP-акселератор

Есть несколько акселераторов (ускорителей работы) для PHP. Здесь рассматривается PHP-APC. Он кэширует результат компиляции PHP-скрипта, которая без акселератора происходит при каждом обращении.

Установка

# apt-get install php-apc

После нужно перезапустить службу

# service php5-fpm restart

Ссылки

Дополнительные модули

Есть множество пакетов, дополняющих возможности PHP-FPM. Для учета изменений после установки модулей нужно перезапустить службу

# service php5-fpm restart

memcached

Для кэширования данных в оперативной памяти.

# apt-get install memcached php5-memcached

MySQL

Для работы с базой данных MySQL.

# apt-get install mysql-server mysql-client php5-mysql

php5-gd

Для обработки изображений.

# apt-get install php5-gd

php5-imagick

Для продвинутой обработки изображений.

# apt-get install php5-imagick

Ссылки