Estou executando o Ubuntu 16.04 Server no XenServer e estou tendo problemas com o limite de arquivos abertos do MySql.
Veja o que eu fiz até agora:
sudo nano /etc/security/limits.conf (referência)
* soft nofile 1024000
* hard nofile 1024000
* soft nproc 102400
* hard nproc 102400
mysql soft nofile 1024000
mysql hard nofile 1024000
sudo nano /etc/init/mysql.conf (referência)
limit nofile 1024000 1024000
limit nproc 102400 102400
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf (referência)
[mysqld_safe]
open_files_limit = 1024000
[mysqld]
open_files_limit = 1024000
Quando o acima não funcionou, eu continuei com o seguinte:
sudo nano /etc/sysctl.conf
fs.file-max = 1024000
sudo nano /etc/pam.d/common-session
session required pam_limits.so
sudo nano /etc/pam.d/common-session-noninteractive
session required pam_limits.so
sudo nano /lib/systemd/system/mysql.service
LimitNOFILE=infinity
LimitMEMLOCK=infinity
Quando eu faço login na minha conta de usuário, tudo parece bem:
ulimit -Hn
1024000
ulimit -Sn
1024000
Se eu fizer o login como mysql, também ficará bom:
mysql@server:~$ ulimit -Hn
1024000
mysql@server:~$ ulimit -Sn
1024000
No entanto, quando olho para o proc:
ps -ef | grep mysql
cat /proc/1023/limits | grep open
Max open files 65536 65536 files
Ou quando eu olho no MySql:
mysql> show global variables like 'open%';
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| open_files_limit | 65536 |
+------------------+-------+
Nos logs (/var/log/mysql/error.log):
2016-07-25T05: 44: 35.453668Z 0 [Warning] Não foi possível aumentar o número de max_open_files para mais de 65536 (request: 1024000)
Estou completamente sem ideias aqui. No começo eu comecei com open_files_limit em 1024, e um dos itens acima deve ter mudado, mas eu preciso ir mais alto. Estou atingindo esse limite já que tenho muitos bancos de dados e tabelas que às vezes têm muitas partições.
Eu até tentei números menos agressivos que 1024000, sem sorte.
Alguma idéia por aí?