Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Mon, 12 Nov 2001 19:05:18 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Mon, 12 Nov 2001 19:05:09 -0500 Received: from vindaloo.ras.ucalgary.ca ([136.159.55.21]:45448 "EHLO vindaloo.ras.ucalgary.ca") by vger.kernel.org with ESMTP id ; Mon, 12 Nov 2001 19:05:04 -0500 Date: Mon, 12 Nov 2001 17:04:57 -0700 Message-Id: <200111130004.fAD04v912703@vindaloo.ras.ucalgary.ca> From: Richard Gooch To: Mike Fedyk Cc: Andrew Morton , Ben Israel , linux-kernel@vger.kernel.org Subject: Re: File System Performance In-Reply-To: <20011112150740.B32099@mikef-linux.matchmail.com> In-Reply-To: <00b201c16b81$9d7aaba0$5101a8c0@pbc.adelphia.net> <3BEFF9D1.3CC01AB3@zip.com.au> <00da01c16ba2$96aeda00$5101a8c0@pbc.adelphia.net> <3BF02702.34C21E75@zip.com.au> <200111121959.fACJxsj08462@vindaloo.ras.ucalgary.ca> <20011112150740.B32099@mikef-linux.matchmail.com> Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Mike Fedyk writes: > On Mon, Nov 12, 2001 at 12:59:54PM -0700, Richard Gooch wrote: > > Here's an idea: add a "--compact" option to tar, so that it creates > > *all* inodes (files and directories alike) in the base directory, and > > then renames newly created entries to shuffle them into their correct > > positions. That should limit the number of block groups that are used, > > right? > > > > It would probably also be a good idea to do that for cp as well, so > > that when I do a "cp -al" of a virgin kernel tree, I can keep all the > > directory inodes together. It will make a cold diff even faster. > > I don't think that would help at all... With the current file/dir > allocator it will choose a new block group for each directory no > matter what the parent is... I thought the current implementation was that when creating a directory, ext2fs searches forward from the block group the parent directory is in, looking for a "relatively free" block group. So, a number of successive calls to mkdir(2) with the same parent directory will result in the child directories being in the same block group. So, creating the directory tree by creating directories in the base directory and then shuffling should result in the directories be spread out over a modest number of block groups, rather than a large number. Addendum to my scheme: leaf nodes should be created in their directories, not in the base directory. IOW, it's only directories that should use this trick. Am I wrong in my understanding of the current algorithm? Regards, Richard.... Permanent: rgooch@atnf.csiro.au Current: rgooch@ras.ucalgary.ca - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/