From owner-freebsd-fs@freebsd.org Mon Jan 4 23:58:17 2016 Return-Path: Delivered-To: freebsd-fs@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id DA7CBA613D4 for ; Mon, 4 Jan 2016 23:58:17 +0000 (UTC) (envelope-from thomasrcurry@gmail.com) Received: from mail-io0-x232.google.com (mail-io0-x232.google.com [IPv6:2607:f8b0:4001:c06::232]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id AA64B1BDA for ; Mon, 4 Jan 2016 23:58:17 +0000 (UTC) (envelope-from thomasrcurry@gmail.com) Received: by mail-io0-x232.google.com with SMTP id q21so170650354iod.0 for ; Mon, 04 Jan 2016 15:58:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; bh=2YMVRdpFH4dgLS76FSii0aKhpfdcu40xh/ux0otdyLE=; b=xl8ImqX9Z7JhqKUJDUwJHhT/aQe8hWqVBOVFk48Bim8Ryae9Kb+Wz6LGq0+KjIMdTj pKCXNjocOlUWgbBlr5cHkVLL2FeBoR9/OQNCTQKCeR00AeMg3qsTAzIaHFi8wFrkLgxJ YxwDclHU9tT5D4ZoYb13GwdfZtyVy5FiMIBHxwLN8qiOXmllG4ZKvXsb3ceL764wiMr6 EAf7F07RUFMghYGYgOaYmjdUHNeA7ASpc9KIxQwtufFv1WruByQncBJtUEdCjEKmo+Wx xYmv/0TS4vgOfohe8hta2b9UKk69fbkvvoH96xoUhrhSZ5TZJ+8Ty5lSKxLqQk66SO0T W0bg== MIME-Version: 1.0 X-Received: by 10.107.3.154 with SMTP id e26mr76692123ioi.99.1451951897049; Mon, 04 Jan 2016 15:58:17 -0800 (PST) Received: by 10.107.4.71 with HTTP; Mon, 4 Jan 2016 15:58:16 -0800 (PST) In-Reply-To: <568A047B.1010000@aldan.algebra.com> References: <8291bb85-bd01-4c8c-80f7-2adcf9947366@email.android.com> <5688D3C1.90301@aldan.algebra.com> <495055121.147587416.1451871433217.JavaMail.zimbra@uoguelph.ca> <568A047B.1010000@aldan.algebra.com> Date: Mon, 4 Jan 2016 18:58:16 -0500 Message-ID: Subject: Re: NFS reads vs. writes From: Tom Curry To: "Mikhail T." Cc: Rick Macklem , freebsd-fs@freebsd.org Content-Type: text/plain; charset=UTF-8 X-Content-Filtered-By: Mailman/MimeDel 2.1.20 X-BeenThere: freebsd-fs@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: Filesystems List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 04 Jan 2016 23:58:17 -0000 On Mon, Jan 4, 2016 at 12:34 AM, Mikhail T. wrote: > On 03.01.2016 20:37, Rick Macklem wrote: > > This issue isn't new. It showed up when Sun introduced NFS in 1985. > > NFSv3 did change things a little, by allowing UNSTABLE writes. > Thank you very much, Rick, for the detailed explanation. > > If you use "sync=disabled" > > (I'm not a ZFS guy, but I think that is what the ZFS option looks > likes) you > > *break* the NFS protocol (ie. violate the RFC) and put your data > at some risk, > > but you will typically get better (often much better) write > performance. > Yes, indeed. Disabling sync got the writing throughput all the way up to > about 86Mb/s... I still don't fully understand, why local writes are > able to achieve this speed without async and without being considered > dangerous. > > Also, the NFS server was recently tweaked so that it could handle 128K > rsize/wsize, > > but the FreeBSD client is limited to MAXBSIZE and this has not been > increased > > beyond 64K. > I just tried lowering ZFS' recordsize to 64k to match MAXBSIZE, but that > didn't help NFS-writing (unless sync is disabled, that is). > > If this SSD is dedicated to the ZIL and is one known to have good write > performance, > > it should help, but in your case the SSD seems to be the bottleneck. > It is a chunk of an older SSD, that also houses the OS. But it is > usually idle, because executables and libraries are cached in the > abundant RAM. I've seen it do 90+Mb/s (sequential)... > > I just tried removing ZIL from the receiving pool -- to force direct > writes -- but it didn't help the case, where the writes go over NFS. > I assume you mean you removed the SLOG from the pool, in which case you most definitely still have a ZIL, its now located on the pool itself. Assuming you still have sync=standard I would venture a guess that writes over NFS would now be measured in KB/s. > However, the local writes -- with reads from NFS -- went from the 56Mb/s > I was seeing earlier to 90Mb/s!.. > > There is got to be a better way to do this -- preferably, some > self-tuning smarts... Thanks again. Yours, > > There is no getting around the performance impact of a synchronous operation, whether its NFS or a database log. If you don't believe me hop on your favorite Windows box, bring up the device manager and disable the write cache on its drive then run some benchmark supporting sync writes. One way to lessen the performance impact is to decrease the latency of writes, which is why SSD SLOGs help so much. Which brings me to my next point.. SSDs are so fast for three main reasons: low latency, large dram buffers, and parallel workloads. Only one of these is of any benefit (latency) as a SLOG. Unfortunately that particular metric is not usually advertised in consumer SSDs where the benchmarks they use to tout 90,000 random write iops consist of massively concurrent, highly compressible, short lived bursts of data. Add that drive as a SLOG and the onboard dram may as well not even exist, and queue depths count for nothing. It will be lucky to pull 2,000 IOPS. Once you start adding in ZFS features like checksums and compression, or network latency in the case of NFS that 2,000 number starts to drop even more. If you fancy a deeper understanding, this excellent article will take you as far down the rabbit hole as you wish to go. It's very informative. http://dtrace.org/blogs/brendan/2009/06/26/slog-screenshots/ > -mi > > _______________________________________________ > freebsd-fs@freebsd.org mailing list > https://lists.freebsd.org/mailman/listinfo/freebsd-fs > To unsubscribe, send any mail to "freebsd-fs-unsubscribe@freebsd.org" >