2

Я получил это сообщение при отладке проблемы в программе PHP.

  • Я уже отредактировал /etc/security/limits.conf и добавил
*         hard    nofile      500000
*         soft    nofile      500000
root      hard    nofile      500000
root      soft    nofile      500000

как указано здесь (https://rtcamp.com/tutorials/linux/increase-open-files-limit/). После этого набрав

ulimit -Hn

а также

ulimit -Sn

раскрывает новый лимит 500000

  • Я уже отредактировал файл /etc/pam.d/common-session и добавил строку
session required pam_limits.so
  • Затем я перезагрузил систему. Моя программа продолжает выдавать исключение при попытке открыть файл # 1025.

  • Я получил PID процесса php (27263), а затем сделал cat /proc /27263 /limit


Limit                     Soft Limit           Hard Limit           Units
Max cpu time              unlimited            unlimited            seconds
Max file size             unlimited            unlimited            bytes
Max data size             unlimited            unlimited            bytes
Max stack size            10485760             unlimited            bytes
Max core file size        0                    unlimited            bytes
Max resident set          unlimited            unlimited            bytes
Max processes             95124                95124                processes
Max open files            1024                 4096                 files
Max locked memory         65536                65536                bytes
Max address space         unlimited            unlimited            bytes
Max file locks            unlimited            unlimited            locks
Max pending signals       95124                95124                signals
Max msgqueue size         819200               819200               bytes
Max nice priority         0                    0
Max realtime priority     0                    0
Max realtime timeout      unlimited            unlimited            us

Как видите, даже после настройки этих общесистемных конфигураций процесс PHP по-прежнему имеет ограничение в 1024 макс.

Зачем?? Как я могу это изменить? Почему общесистемные настройки не работают для этого конкретного случая?

Спасибо

1 ответ1

2

Короткий ответ (за лимит 500000)

  1. Отредактируйте /etc/security/limits.conf и добавьте это в конец файла:
*         hard    nofile      500000
*         soft    nofile      500000
root      hard    nofile      500000
root      soft    nofile      500000
  1. Отредактируйте файл /etc /sysconfig /httpd и добавьте в конце add:
ulimit -n 500000
  1. Перезагрузка (не знаю, если это абсолютно необходимо)

  2. Бинго!

Длинный ответ

Оказывается, что в соответствии с Make ulimits работают с start-stop-daemon и этим обсуждением в списке рассылки Red Hat,

limit.conf(5) - это конфигурация для pam_limits(8), которая активируется стеком PAM в соответствии с конфигурацией в /etc/pam.d. Однако start-stop-daemon(8), запущенный из сценария init.d, не проходит через стек PAM, поэтому такие настройки никогда не применяются.

Или, проще говоря,

/etc/security/limits.conf применяется к входам в систему, а пользователь "apache" не выполняет вход.

Решение, предложенное в первой ссылке, состоит в том, чтобы отредактировать скрипт init.d и добавить ulimit -n в конец скрипта.

Однако, как можно заметить во второй ссылке, если вы отредактируете скрипт /etc/init.d/httpd, обновление системы может перезаписать файл, и изменения исчезнут.

Вот почему они предложили здесь, здесь и здесь, отредактировать файл /etc /sysconfig /httpd и ввести там команду.

Это то, что я сделал, и теперь я получил прекрасный cat /proc /pid /limit, как я и хотел:

Limit                     Soft Limit           Hard Limit           Units
Max cpu time              unlimited            unlimited            seconds
Max file size             unlimited            unlimited            bytes
Max data size             unlimited            unlimited            bytes
Max stack size            10485760             unlimited            bytes
Max core file size        0                    unlimited            bytes
Max resident set          unlimited            unlimited            bytes
Max processes             500000               500000               processes
Max open files            500000               500000               files
Max locked memory         65536                65536                bytes
Max address space         unlimited            unlimited            bytes
Max file locks            unlimited            unlimited            locks
Max pending signals       95124                95124                signals
Max msgqueue size         819200               819200               bytes
Max nice priority         0                    0
Max realtime priority     0                    0
Max realtime timeout      unlimited            unlimited            us

и программа больше не падает.

Кстати, система RHEL Server 6.6.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .