sysctl maxfiles

Jeremy Chadwick koitsu at FreeBSD.org
Sat Sep 27 03:02:09 UTC 2008


On Sat, Sep 27, 2008 at 11:10:01AM +1000, Aristedes Maniatis wrote:
> By default FreeBSD 7.0 shipped with the sysctls set to:
>
> kern.maxfiles: 12328
> kern.maxfilesperproc: 11095
>
> We recently bumped up against these limits in an unfortunate way and we 
> are going to raise them. I have some questions:
>
> * why are the numbers set the way they are? They aren't round numbers,  
> they aren't powers of 2. But they were arrived at somehow with planning 
> and thought presumably, so when I increase them I'd like to know a bit 
> more about why these numbers were chosen.

The values are calculated when the kernel is loaded, based on many other
parameters; you won't find "12328" hard-coded anywhere in the kernel
source, for example.

The Handbook goes over this fact:

http://www.freebsd.org/doc/en/books/handbook/configtuning-kernel-limits.html

By the way, DO NOT let the term "maxusers" make you think that has
something to do with the number of users which can be logged in
simultaneously or added to a box.  It has nothing to do with that.

Anyway, I'd like to know why you have so many fds open simultaneously in
the first place.  We're talking over 11,000 fds actively open at once --
this is not a small number.  What exactly is this machine doing?  Are
you absolutely certain tuning this higher is justified?  Have you looked
into the possibility that you have a program which is exhausting fds by
not closing them when finished?  (Yes, this is quite common; I've seen
bad Java code cause this problem on Solaris.)

> * why are the numbers so close together? Surely there should be more gap 
> between max files per process and the max files for the whole system. 
> What happens is that with one runaway broken process is that it hits 
> 11095 and the 1233 files left for everything else is not enough (on many 
> servers) to allow the admin to login using ssh. That gets very ugly very 
> quickly.

Others will have to comment on this.

> * Under OSX (both server and client), these numbers are 12288 and 10240. 
> A bit more of a gap, but not terribly different to FreeBSD. Still 
> interesting that someone changed these numbers just slightly.

OS X isn't based on FreeBSD 7.  The calculation logic has changed over
time.

> * why do these controls exist at all? That is, if they were set to  
> infinite what part of the system would be exhausted by a runaway process 
> which kept opening files? Would the kernel run out of memory? What memory 
> setting would be relevant here? I don't want to set maxfiles too high and 
> then run out of some other resource which this maxfiles was protecting.

You're asking for trouble setting these values to the equivalent of
unlimited.  Instead of asking "what would happen", you should be asking
"why would I need to do that".

Regarding memory implications, the Handbook goes over it.

-- 
| Jeremy Chadwick                                jdc at parodius.com |
| Parodius Networking                       http://www.parodius.com/ |
| UNIX Systems Administrator                  Mountain View, CA, USA |
| Making life hard for others since 1977.              PGP: 4BD6C0CB |



More information about the freebsd-stable mailing list