Date: Mon, 06 Jan 2014 13:54:11 +0200 From: Andriy Gapon <avg@FreeBSD.org> To: Vladimir Sharun <atz@ukr.net> Cc: Current FreeBSD <freebsd-current@FreeBSD.org> Subject: Re: ARC "pressured out", how to control/stabilize ? (reformatted to text/plain) Message-ID: <52CA9963.1050507@FreeBSD.org> In-Reply-To: <1389005433.815055146.2dcjke36@frv45.ukr.net> References: <1388839805.123581691.q97ijp8l@frv45.ukr.net> <52C93E4D.1050100@FreeBSD.org> <1389005433.815055146.2dcjke36@frv45.ukr.net>
next in thread | previous in thread | raw e-mail | index | archive | help
on 06/01/2014 13:14 Vladimir Sharun said the following: > Dear Andriy and FreeBSD community, > > I got the few minutes run for this dtrace hook; here's the output for 15 minutes run: > > http://pastebin.com/pKm9kLwa > > Does it explain something ? The following makes me suspect a problem with L2ARC compression code. zfs.ko`l2arc_feed_thread+0x7d9 kernel`fork_exit+0x9a kernel`0xffffffff8069ad6e 95131 I am not sure if the buffers are leaked somehow or if they are actually in use. It's one of the very few places where data buffers are allocated without charging ARC. In all other places it's quite easy to match allocations and deallocations. But in L2ARC it is not obvious that all buffers get freed or when that happens. >> on 04/01/2014 14:50 Vladimir Sharun said the following: >> [snip] >>> ARC: 28G Total, 2085M MFU, 20G MRU, 29M Anon, 1858M Header, 3855M Other >> [snip] >>> ITEM SIZE LIMIT USED FREE REQ FAIL SLEEP >> [snip] >>> zio_data_buf_131072: 131072, 0, 488217, 9,287155442, 0, 0 >> >> I noticed a particular discrepancy between reported ARC usage and sizes of UMA >> zones used by ZFS code: >> >> 488217 * 131072 = ~59GB right there. >> >> There are several possibilities for this discrepancy: >> - bad accounting or reporting of ARC stats >> - those 128K buffers being used in a special way and thus not accounted as ARC >> - some sort of resource leak >> >> You could try to use DTrace to gather the stacks of all code paths that lead to >> allocation of those buffers. Something like: >> >> fbt::zio_data_buf_alloc:entry >> /arg0 == 131072/ >> { >> @[stack()] = count(); >> } >> >> This could be a start for understanding the issue. >> -- Andriy Gapon
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?52CA9963.1050507>