From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from relay.sgi.com (relay3.corp.sgi.com [198.149.34.15]) by oss.sgi.com (Postfix) with ESMTP id 472D07F5A for ; Tue, 1 Dec 2015 15:10:53 -0600 (CST) Received: from cuda.sgi.com (cuda1.sgi.com [192.48.157.11]) by relay3.corp.sgi.com (Postfix) with ESMTP id E0682AC005 for ; Tue, 1 Dec 2015 13:10:52 -0800 (PST) Received: from mail-lf0-f48.google.com (mail-lf0-f48.google.com [209.85.215.48]) by cuda.sgi.com with ESMTP id BIUMcqtuJ1wlHGjV (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO) for ; Tue, 01 Dec 2015 13:10:47 -0800 (PST) Received: by lfdl133 with SMTP id l133so25696538lfd.2 for ; Tue, 01 Dec 2015 13:10:45 -0800 (PST) MIME-Version: 1.0 In-Reply-To: <20151201210417.GY19199@dastard> References: <20151130141000.GC24765@bfoster.bfoster> <565C5D39.8080300@scylladb.com> <20151130161438.GD24765@bfoster.bfoster> <565D639F.8070403@scylladb.com> <20151201131114.GA26129@bfoster.bfoster> <565DA784.5080003@scylladb.com> <20151201145631.GD26129@bfoster.bfoster> <565DBB3E.2010308@scylladb.com> <20151201210417.GY19199@dastard> Date: Tue, 1 Dec 2015 16:10:45 -0500 Message-ID: Subject: Re: sleeps and waits during io_submit From: Glauber Costa List-Id: XFS Filesystem from SGI List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: xfs-bounces@oss.sgi.com Sender: xfs-bounces@oss.sgi.com To: Dave Chinner Cc: Avi Kivity , Brian Foster , xfs@oss.sgi.com On Tue, Dec 1, 2015 at 4:04 PM, Dave Chinner wrote: > On Tue, Dec 01, 2015 at 05:22:38PM +0200, Avi Kivity wrote: >> On 12/01/2015 04:56 PM, Brian Foster wrote: >> >On Tue, Dec 01, 2015 at 03:58:28PM +0200, Avi Kivity wrote: >> >>> io_submit() can probably block in a variety of >> >>>places afaict... it might have to read in the inode extent map, allocate >> >>>blocks, take inode/ag locks, reserve log space for transactions, etc. >> >>Any chance of changing all that to be asynchronous? Doesn't sound too hard, >> >>if somebody else has to do it. >> >> >> >I'm not following... if the fs needs to read in the inode extent map to >> >prepare for an allocation, what else can the thread do but wait? Are you >> >suggesting the request kick off whatever the blocking action happens to >> >be asynchronously and return with an error such that the request can be >> >retried later? >> >> Not quite, it should be invisible to the caller. > > I have a pony I can sell you. > >> That is, the code called by io_submit() >> (file_operations::write_iter, it seems to be called today) can kick >> off this operation and have it continue from where it left off. > > This is a problem that people have tried to solve in the past (e.g. > syslets, etc) where the thread executes until it has to block, and > then it's handled off to a worker thread/syslet to block and the > main process returns with EIOCBQUEUED. > > Basically, you're asking for a real AIO infrastructure to > beintroduced into the kernel, and I think that's beyond what us XFS > guys can do... > >> >>> Reducing the frequency of block allocation/frees might also be >> >>>another help (e.g., preallocate and reuse files, >> >>Isn't that discouraged for SSDs? >> >> >> >Perhaps, if you're referring to the fact that the blocks are never freed >> >and thus never discarded..? Are you running fstrim? >> >> mount -o discard. And yes, overwrites are supposedly more expensive >> than trim old data + allocate new data, but maybe if you compare it >> with the work XFS has to do, perhaps the tradeoff is bad. > > Oh, you do realise that using "-o discard" causes significant delays > in journal commit processing? i.e. the journal commit completion > blocks until all the discards have been submitted and waited on > *synchronously*. This is a problem with the linux block layer in > that blkdev_issue_discard() is a synchronous operation..... > > Hence if you are seeing delays in transactions (e.g. timestamp updates) > it's entirely possible that things will get much better if you > remove the discard mount option. It's much better from a performance > perspective to use the fstrim command every so often - fstrim issues > discard operations in the context of the fstrim process - it does > not interact with the transaction subsystem at all. Hi Dave, This is news to me. However, in the disk that we have used during the acquisition of this trace, discard doesn't seem to be supported: $ sudo fstrim /data/ fstrim: /data/: the discard operation is not supported In that case, if I understand correctly the discard mount option should be a noop, no? That recommendation is great for our general case, though. > > Cheers, > > Dave. > -- > Dave Chinner > david@fromorbit.com _______________________________________________ xfs mailing list xfs@oss.sgi.com http://oss.sgi.com/mailman/listinfo/xfs