Fixação de ulimit: arquivos abertos: não é possível modificar o limite: Operação não permitida

5

Eu testei isso em diferentes instalações GNU / Linux:

perl -e 'while(1){open($a{$b++}, "<" ,"/dev/null") or die $b;print " $b"}'

Sistema A e D

O primeiro limite que eu atingi é 1024. É facilmente gerado colocando isso em /etc/security/limits.conf:

*                hard    nofile          1048576

e, em seguida, execute:

ulimit -n 1048576
echo 99999999 | sudo tee /proc/sys/fs/file-max

Agora o teste vai para 1048576.

No entanto, parece que não posso aumentá-lo acima de 1048576. Se eu colocar 1048577 no limits.conf, ele será simplesmente ignorado.

O que está causando isso?

Sistema B

No sistema B, não consigo nem chegar a 1048576:

echo 99999999 | sudo tee /proc/sys/fs/file-max

/etc/security/limits.conf:

*                hard    nofile          1048576

Aqui eu recebo:

$ ulimit -n 65537
bash: ulimit: open files: cannot modify limit: Operation not permitted
$ ulimit -n 65536
#OK

De onde veio esse limite?

Sistema C

Este sistema também tem o limite 1048576 em limits.conf e 99999999 em / proc / sys / fs / file-max.

Mas aqui o limite é 4096:

$ ulimit -n 4097
-bash: ulimit: open files: cannot modify limit: Operation not permitted
$ ulimit -n 4096
# OK

Como faço para aumentar isso para (pelo menos) 1048576?

(Nota para si mesmo: não faça: echo 18446744073709551616 | sudo tee /proc/sys/fs/file-max )

    
por Ole Tange 15.04.2017 / 13:33

1 resposta

2

Verifique se /etc/ssh/sshd_config contém:

UsePAM=yes

e que /etc/pam.d/sshd contém:

session    required   pam_limits.so

Ainda não há resposta para o porquê 1048576 é max.

O 1048576 parece ser por processo. Então, por ter vários processos, esse limite pode ser superado.

    
por 17.04.2017 / 08:59