From owner-freebsd-current@FreeBSD.ORG Mon Nov 18 09:21:02 2013 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id C1A43373; Mon, 18 Nov 2013 09:21:02 +0000 (UTC) Received: from mail-ee0-x230.google.com (mail-ee0-x230.google.com [IPv6:2a00:1450:4013:c00::230]) (using TLSv1 with cipher ECDHE-RSA-RC4-SHA (128/128 bits)) (No client certificate requested) by mx1.freebsd.org (Postfix) with ESMTPS id 0DA4029A0; Mon, 18 Nov 2013 09:21:01 +0000 (UTC) Received: by mail-ee0-f48.google.com with SMTP id e49so2313646eek.21 for ; Mon, 18 Nov 2013 01:21:00 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=sender:message-id:date:from:user-agent:mime-version:to:cc:subject :references:in-reply-to:content-type:content-transfer-encoding; bh=WdHtD+khd2d/VfhXzRyplRr7wBb2XCgdBHz2xxlmbds=; b=ZGRKncfEbYrBaKzzzAZJBrXQ0K4IvvEJOSTHl0p/jFpte5nRQj9n2wd+67+nrfaEmG dIYa8F0Uu+jGthVNW8IUyza8LQ53isJkJRGd0ZViUACzV1Pmex4NQWkZmtUxODoKpDPB 3wP+WVd+Tnwe48dJolZrL40Ufa5oe81wINmYqlC2uIqoIvd6/GK0CIxYmYxyo7hEvDD1 qCMDIAo0rm5NCWMBdVm6RfXgsGMDAy1EmHF2sqNxw4bBbzOJ5+E9rFmrxHSenf9/tskw x0Esueh6EnGKWqWhj0j29mjn82NEbg2j4CPuxK3Dj26k/gSaKno98MPsXqRyYrFKes31 oMDA== X-Received: by 10.14.108.9 with SMTP id p9mr20316683eeg.8.1384766460341; Mon, 18 Nov 2013 01:21:00 -0800 (PST) Received: from mavbook.mavhome.dp.ua ([178.137.150.35]) by mx.google.com with ESMTPSA id s3sm35801312eeo.3.2013.11.18.01.20.58 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Mon, 18 Nov 2013 01:20:59 -0800 (PST) Sender: Alexander Motin Message-ID: <5289DBF9.80004@FreeBSD.org> Date: Mon, 18 Nov 2013 11:20:57 +0200 From: Alexander Motin User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:24.0) Gecko/20100101 Thunderbird/24.1.0 MIME-Version: 1.0 To: Adrian Chadd Subject: Re: UMA cache back pressure References: <52894C92.60905@FreeBSD.org> In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: "freebsd-hackers@freebsd.org" , "freebsd-current@freebsd.org" X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.16 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 18 Nov 2013 09:21:02 -0000 On 18.11.2013 10:41, Adrian Chadd wrote: > Your patch does three things: > > * adds a couple new buckets; These new buckets make bucket size self-tuning more soft and precise. Without them there are buckets for 1, 5, 13, 29, ... items. While at bigger sizes difference about 2x is fine, at smallest ones it is 5x and 2.6x respectively. New buckets make that line look like 1, 3, 5, 9, 13, 29, reducing jumps between steps, making algorithm work softer, allocating and freeing memory in better fitting chunks. Otherwise there is quite a big gap between allocating 128K and 5x128K of RAM at once. > * reduces some lock contention More precisely patch adds check for congestion on free to grow bucket sizes same as on allocation. As consequence that indeed should reduce lock congestion, but I don't have specific numbers. All I see is that VM and UMA mutexes no longer appear in profiling top after all these changes. * does soft back pressure In this list you have missed mentioning small but major point of the patch -- we should prevent problems, not just solve them. As I have written in original email, this specific change shown me 1.5x performance improvement in low-memory condition. As I understand, that happened because VM no longer have to repeatedly allocate and free hugely oversized buckets of 10-15 * 128K. > * does the aggressive backpressure. After all above that is mostly just a safety belt. With 40GB RAM that code was triggered only couple times during full hour of testing with debug logging inserted there. On machine with 2GB RAM it is triggered quite regularly and probably that is unavoidable since even with lowest bucket size of one item 24 CPUs mean 48 cache buckets, i.e. up to 6MB of otherwise unreleasable memory for single 128K zone. > So, do you get any benefits from just the first one, or first two? I don't see much reason to handle that in pieces. As I have described above, each part has own goal, but they much better work together. > On 17 November 2013 15:09, Alexander Motin wrote: >> Hi. >> >> I've created patch, based on earlier work of avg@, to add back pressure to >> UMA allocation caches. The problem of physical memory or KVA exhaustion >> existed there for many years and it is quite critical now for improving >> systems performance while keeping stability. Changes done in memory >> allocation last years improved situation. but haven't fixed completely. My >> patch solves remaining problems from two sides: a) reducing bucket sizes >> every time system detects low memory condition; and b) as last-resort >> mechanism for very low memory condition, it cycling over all CPUs to purge >> their per-CPU UMA caches. Benefit of this approach is in absence of any >> additional hard-coded limits on cache sizes -- they are self-tuned, based on >> load and memory pressure. >> >> With this change I believe it should be safe enough to enable UMA allocation >> caches in ZFS via vfs.zfs.zio.use_uma tunable (at least for amd64). I did >> many tests on machine with 24 logical cores (and as result strong allocation >> cache effects), and can say that with 40GB RAM using UMA caches, allowed by >> this change, by two times increases results of SPEC NFS benchmark on ZFS >> pool of several SSDs. To test system stability I've run the same test with >> physical memory limited to just 2GB and system successfully survived that, >> and even showed results 1.5 times better then with just last resort measures >> of b). In both cases tools/umastat no longer shows unbound UMA cache growth, >> that makes me believe in viability of this approach for longer runs. >> >> I would like to hear some comments about that: >> http://people.freebsd.org/~mav/uma_pressure.patch -- Alexander Motin