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

Материал из K.Wiki
Перейти к: навигация, поиск
(Шаблоны)
(Шаблоны)
Строка 79: Строка 79:
 
listen = /var/run/php7.0-fpm_$pool.sock
 
listen = /var/run/php7.0-fpm_$pool.sock
  
;; Пользователь и группа, которые владеют файлом UNIX-сокета.
+
;; Размер очереди одновременно ожидающих подключений к сокету.
 +
;; Значение по-умолучению: 511 (-1 on FreeBSD and OpenBSD)
 +
; listen.backlog = 511
 +
 
 +
;; Пользователь и группа, которые владеют файлом UNIX-сокета, если он используется.
 
;; Пользователь, от имени которого работает WEB-сервер, должен иметь права на чтение.
 
;; Пользователь, от имени которого работает WEB-сервер, должен иметь права на чтение.
 +
;; По-умолчанию, совпадают с пользователем и группой, от имени которых запущен процесс.
 
listen.owner = www-data
 
listen.owner = www-data
 
listen.group = www-data
 
listen.group = www-data
Строка 87: Строка 92:
 
; listen.mode = 0660
 
; listen.mode = 0660
  
 +
;; When POSIX Access Control Lists are supported you can set them using
 +
;; these options, value is a comma separated list of user/group names.
 +
;; When set, listen.owner and listen.group are ignored
 +
; listen.acl_users =
 +
; listen.acl_groups =
 +
 +
;; List of addresses (IPv4/IPv6) of FastCGI clients which are allowed to connect.
 +
;; Equivalent to the FCGI_WEB_SERVER_ADDRS environment variable in the original
 +
;; PHP FCGI (5.2.2+). Makes sense only with a tcp listening socket. Each address
 +
;; must be separated by a comma. If this value is left blank, connections will be
 +
;; accepted from any ip address.
 +
;; Default Value: any
 +
; listen.allowed_clients = 127.0.0.1
  
 
;; Ограничение по времени, после которого запросы будут считаться медленными.
 
;; Ограничение по времени, после которого запросы будут считаться медленными.
Строка 94: Строка 112:
 
;; Обязателен, если задан request_slowlog_timeout
 
;; Обязателен, если задан request_slowlog_timeout
 
; slowlog = log/$pool.log.slow
 
; slowlog = log/$pool.log.slow
 
  
 
;; Считать /var/www/$pool корневой директорией для скриптов.
 
;; Считать /var/www/$pool корневой директорией для скриптов.
 
;; Нужно скорректировать все пути и обеспечить доступ к файлам сокетов и другим необходимым службам внутри этой директории.
 
;; Нужно скорректировать все пути и обеспечить доступ к файлам сокетов и другим необходимым службам внутри этой директории.
 
; chroot = /var/www/$pool
 
; chroot = /var/www/$pool
 
  
 
;; Передать переменные октужения, такие как LD_LIBRARY_PATH.
 
;; Передать переменные октужения, такие как LD_LIBRARY_PATH.
 
;; Все $VARIABLEs берутся из текущего окружения.
 
;; Все $VARIABLEs берутся из текущего окружения.
 
;; По-умолчанию, env пустой.
 
;; По-умолчанию, env пустой.
; env[HOSTNAME] = $HOSTNAME
+
env[HOSTNAME] = $HOSTNAME
; env[PATH] = /usr/local/bin:/usr/bin:/bin
+
env[PATH] = /usr/local/bin:/usr/bin:/bin
 
; env[TMP] = /tmp
 
; env[TMP] = /tmp
 
; env[TMPDIR] = /tmp
 
; env[TMPDIR] = /tmp

Версия 01:49, 24 января 2017

Установка

# apt-get install php-fpm

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

;cgi.fix_pathinfo=1

на

cgi.fix_pathinfo = 0

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

sudo service php7.0-fpm reload

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

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

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

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

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

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

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

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

sudo service php7.0-fpm reload

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

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

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


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


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

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

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

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

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

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

Шаблоны

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

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

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

;; Размер очереди одновременно ожидающих подключений к сокету.
;; Значение по-умолучению: 511 (-1 on FreeBSD and OpenBSD)
; listen.backlog = 511

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

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

;; When POSIX Access Control Lists are supported you can set them using
;; these options, value is a comma separated list of user/group names.
;; When set, listen.owner and listen.group are ignored
; listen.acl_users =
; listen.acl_groups =

;; List of addresses (IPv4/IPv6) of FastCGI clients which are allowed to connect.
;; Equivalent to the FCGI_WEB_SERVER_ADDRS environment variable in the original
;; PHP FCGI (5.2.2+). Makes sense only with a tcp listening socket. Each address
;; must be separated by a comma. If this value is left blank, connections will be
;; accepted from any ip address.
;; Default Value: any
; listen.allowed_clients = 127.0.0.1

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

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

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

;; Передать переменные октужения, такие как LD_LIBRARY_PATH.
;; Все $VARIABLEs берутся из текущего окружения.
;; По-умолчанию, env пустой.
env[HOSTNAME] = $HOSTNAME
env[PATH] = /usr/local/bin:/usr/bin:/bin
; env[TMP] = /tmp
; env[TMPDIR] = /tmp
; env[TEMP] = /tmp

Изменение глобальных настроек 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. Для учета изменений после установки модулей нужно перезапустить службу

sudo service php7.0-fpm restart

memcached

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

sudo apt-get install memcached php-memcached

MySQL

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

sudo apt-get install mysql-server mysql-client php-mysql

php-gd

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

sudo apt-get install php-gd

php-imagick

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

sudo apt-get install imagemagick php-imagick

Ссылки