Увеличить максимальное количество разрешенных открытых файлов для Nginx и PHP-FPM в Ubuntu

Мне нужно увеличить максимальное количество разрешенных открытых файлов для Nginx 1.10 и PHP-FPM 7 в Ubuntu 16.04. Согласно некоторым руководствам я изменил максимальное количество открытых файлов для каждого пользователя в /etc/security/limits.conf

*    soft nofile 64000
*    hard nofile 68000

Я также изменил максимальное количество открытых файлов для всей системы в /etc/sysctl.conf

fs.file-max = 200500

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

igor@ubuntu:~$ ulimit -Sn
64000
igor@ubuntu:~$ ulimit -Hn
68000

. Как видите, ограничения применяются к пользователям. Моя проблема в том, что я не могу изменить ограничения для Nginx и PHP

igor@ubuntu:~$ sudo ps aux|grep nginx
root      1124  0.0  0.0  45988   980 ?        Ss   01:04   0:00 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
www-data  1125  0.0  0.2  46164  2372 ?        S    01:04   0:00 nginx: worker process
igor      2754  0.0  0.0   5108   848 pts/6    S+   01:14   0:00 grep --color=auto nginx
igor@ubuntu:~$ cat /proc/1124/limits
Limit                     Soft Limit           Hard Limit           Units     

.....
Max open files            1024                 4096                 files     
.....  

И то же самое для php

igor@ubuntu:~$ sudo ps aux|grep php
root      1097  0.0  2.1 118388 22496 ?        Ss   01:04   0:00 php-fpm: master process (/etc/php/7.0/fpm/php-fpm.conf)
www-data  1140  0.0  0.5 118388  5532 ?        S    01:04   0:00 php-fpm: pool www
www-data  1141  0.0  0.5 118388  5532 ?        S    01:04   0:00 php-fpm: pool www
igor      2795  0.0  0.0   5108   852 pts/6    S+   01:20   0:00 grep --color=auto php
igor@ubuntu:~$ cat /proc/1097/limits
Limit                     Soft Limit           Hard Limit           Units     
.....
Max open files            1024                 4096                 files     
.....

Как я могу изменить ограничения для PHP и NGINX?

2
задан 28 August 2016 в 11:34
1 ответ

Вам необходимо добавить эту конфигурацию в файл модуля systemd . Лучше всего сделать это через подключаемый файл.

mkdir /etc/systemd/system/nginx.service.d
echo "[Service]
LimitNOFILE=10000" > /etc/systemd/system/nginx.service.d/local.conf
systemctl daemon-reload
systemctl restart nginx

Затем повторите это для файла модуля php7.0-fpm.service .

Вы также можете установить значения по умолчанию в /etc/systemd/system.conf , но рекомендуется использовать подключаемые файлы.

2
ответ дан 3 December 2019 в 11:32

Теги

Похожие вопросы