Не могу найти источник максимального количества открытых файлов (ulimit) для mysql-процесса - PullRequest
0 голосов
/ 31 января 2019

Я был делегирован для управления MySQL-сервером (RHEL 7), и теперь у меня странная ситуация.RPM-пакет от Oracle, который использует init.d-скрипты, а не systemd.Если я проверяю пределы запущенного MySQL-Server-Process, я получаю 5000. Позвольте мне показать вам, как я проверил, что:

ps -ef | grep mysql | grep -v grep
root     17184     1  0  2018 ?        00:00:00 /bin/sh /usr/bin/mysqld_safe --datadir=/db/data1 --pid-file=/var/run/mysqld/mysqld.pid
mysql    17902 17184  0  2018 ?        01:14:22 /usr/sbin/mysqld --basedir=/usr --datadir=/db/data1 --plugin-dir=/usr/lib64/mysql/plugin --user=mysql --log-error=/var/log/mysql/mysqld.err --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306

cat /proc/17902/limits 
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            8388608              unlimited            bytes     
Max core file size        0                    unlimited            bytes     
Max resident set          unlimited            unlimited            bytes     
Max processes             15066                15066                processes 
Max open files            5000                 5000                 files     
Max locked memory         65536                65536                bytes     
Max address space         unlimited            unlimited            bytes     
Max file locks            unlimited            unlimited            locks     
Max pending signals       15066                15066                signals   
Max msgqueue size         819200               819200               bytes     
Max nice priority         0                    0                    
Max realtime priority     0                    0                    
Max realtime timeout      unlimited            unlimited            us  

Как вы можете видеть, жесткое и мягкое ограничение «Максимальное количество открытых файлов»установлен на 5000. Мой вопрос: где это значение установлено?Я уже проверил следующие файлы:

  • / etc / security / limit.conf => Этот файл пуст, за исключением некоторых комментариев
  • / etc / security / limit.d / 20-nproc.conf => Это единственный файл в файле limit.d.Содержимое:

    *          soft    nproc     4096
    root       soft    nproc     unlimited
    
  • ulimit -n от имени root: 1024

  • ulimit -n от имени пользователя mysql: 1024

  • / etc / my.cnf не содержит значения max_open_files

  • / etc / my.cnf.d пусто

Любая идея, где это значение установлено?

1 Ответ

0 голосов
/ 31 января 2019

Это должно зависеть от того, что вы установили в /etc/security/limits.conf, более подробную информацию смотрите здесь https://unix.stackexchange.com/questions/152186/mysql-max-open-files-more-than-1024 В конце концов подумайте над добавлением всего содержимого my.cnf

...