Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 01 Aug 2008 20:07:48 +0200
From:      Kris Kennaway <kris@FreeBSD.org>
To:        Royce Williams <royce@alaska.net>
Cc:        freebsd-stable@FreeBSD.org
Subject:   Re: 6.3-RELEASE-p3 recurring panics on multiple SM PDSMi+
Message-ID:  <489350F4.5070009@FreeBSD.org>
In-Reply-To: <48933557.8010904@alaska.net>
References:  <488638DA.7010005@alaska.net>	<20080723053404.GA46617@eos.sc1.parodius.com>	<4886D1E9.1090905@alaska.net> <48933557.8010904@alaska.net>

next in thread | previous in thread | raw e-mail | index | archive | help
Royce Williams wrote:
> Royce Williams wrote, on 7/22/2008 10:38 PM:
>> Jeremy Chadwick wrote, on 7/22/2008 9:34 PM:
>>> On Tue, Jul 22, 2008 at 11:45:30AM -0800, Royce Williams wrote:
>>>> We have 10 SuperMicro PDSMi+ 5015M-MTs that are panic'ing every few
>>>> days.  This started shortly after upgrade from 6.2-RELEASE to
>>>> 6.3-RELEASE with freebsd-update.
>>> We use the same hardware (board and chassis), and have no such problems
>>> running both RELENG_6 and RELENG_7.
>>>
>>> I don't think your issue is specific to the board or chassis.  Kris's
>>> explanation makes a lot more sense.  :-)
>> Jeremy/Kris/Clifton -
>>
>> Looks like we have consensus. :-)  Thanks, all of you, for your
>> helpful insight.
>>
>> I've bumped vm.kmem_size up to 400M on half of the affected boxes,
>> leaving the other half as a control group.  I'll report back once I
>> have something to report.
> 
> After having bumped up to 400M, a few boxes panic'd again yesterday.  
> I caught a core, and it is "kmem_map too small", just as Kris 
> suspected:
> 
> Jul 31 15:38:05 [redacted] savecore: reboot after panic: kmem_malloc(4096): kmem_map too small: 419430400 total allocated
> 
> 
> The docs state that 400M should be plenty for systems up to 6G, but 
> Kris said earlier in this thread that it's better to say 'increase 
> until the pain stops'. :-)  Accordingly, I have some some follow-up 
> questions; hopefully, this will be useful to others.
> 
> - What is a reasonable increment? (I'm trying 448M next).
> 
> - What are the practical and hard maximums?
> 
> - I suspect that it's worth trying to make kmem 'as big as I need, but 
> no bigger', so that non-kernel memory is also maximized?
> 
> - In a larger sense, if 400M is probably big enough for 6G systems, 
> and these are 4G systems, should I be suspicious that 400M isn't
> cutting it?  In other words, is there a point at which should I be 
> looking for obvious places where the kernel is eating too much memory 
> and reduce them, rather than feeding it more?  
> 
> For example, I recall now that a network guy in my group did some 
> sysctl tuning relating to networking on these systems, and I see 
> from man tuning(7) that a number of these tweaks (obviously) can 
> cause increased kernel consumption.
> 
> $ egrep -v '^#|^$' /etc/sysctl.conf | sort
> kern.corefile=/var/cores/%U/%N-%P.core
> kern.ipc.maxsockbuf=8388608
> kern.ipc.maxsockets=32768
> kern.ipc.nmbclusters=65535
> kern.ipc.somaxconn=4096
> kern.maxfiles=262144
> kern.maxfilesperproc=65535
> net.inet.ip.portrange.first=8192
> net.inet.ip.portrange.hifirst=8192
> net.inet.ip.portrange.hilast=65535
> net.inet.ip.portrange.last=65535
> net.inet.ipf.fr_tcpclosed=60
> net.inet.ipf.fr_tcpclosewait=120
> net.inet.ipf.fr_tcphalfclosed=300
> net.inet.ipf.fr_udptimeout=120
> net.inet.tcp.delayed_ack=0
> net.inet.tcp.inflight.enable=0
> net.inet.tcp.msl=10000
> net.inet.tcp.mssdflt=1460
> net.inet.tcp.recvspace=65536
> net.inet.tcp.rfc1323=1
> net.inet.tcp.sendspace=65536
> net.inet.udp.maxdgram=57344
> net.inet.udp.recvspace=65535
> vfs.nfs.iodmax=32
> vfs.nfs.iodmin=8
> 
> 
> My apologies for not including this sooner.  I didn't think of it
> until yesterday, primarily because it had been fine under 6.2.  In
> retrospect, that was bad reasoning.
> 
> Royce
> 

The statement that "400MB should be enough for up to 6GB" is completely 
bogus.  The amount of memory your kernel needs is a function of the work 
you give it to do.

On i386 the kernel only has 1GB of address space though you can increase 
it by tuning KVA_PAGES at the expense of less memory available to user 
processes (everything comes out of 4GB address space).  So that is the 
upper bound although other things need to fit in there too.

On amd64 the situation is more complicated but on older versions than 
8.0 there is 2GB for the kernel address space and in practise a limit of 
about 1500MB of kmem.

It is possible that you are hitting a memory leak but I would just 
increase kmem further and see if it persists.  Looking at vmstat -m etc 
may help to figure out if something is leaking over time.

Kris



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?489350F4.5070009>