On Thu, Jun 22, 2000, Don Lewis wrote:
> On Jun 22, 5:11pm, "Daniel O'Connor" wrote:
> } Subject: Re: How many files can I put in one diretory?
> }
> } On 22-Jun-00 Luigi Rizzo wrote:
> } > that sounds insane! Because a name is a name, why dont they call
> } > those files xx/yy/zz/tt.html and the like, to get down to a more
> } > reasonable # of files per directory.
> } >
> } > Or use a single file and a cgi which extracts things from the right place.
> } > In such a context, i assume that the best place to do the name lookup
> } > is in the app, not in the kernel.
> }
> } Yeah.. This is why databases where invented :)
> }
> } FYI 40000 in a directory really makes directory listings slow.. 2 million would
> } suck :)
>
> Only if directory lookups use a sequential search. Not all filesystem
> implementations sequentially scan directory entries. Some use btrees or
> other ways of quickly finding the desired directory entry. Even so,
> you probably still would want to avoid doing an "ls" or an "echo *" ;-)
>
> I'd recommend looking at how squid stores its disk cache. It has a
> very similar performance problem to solve.
Squid uses a 2-level directory hierarchy with a simple mapping
directory<->filename. Since each disk object in squid has a swap file
number, translating between directory name and swap file number is
only two MOD (%) operations away.
The main trouble with squid's UFS layout isn't in the ls time, but
in the access time. When looking at a file, you have to do a set
of file path component lookups (/cache1/00/01/000102 would need
a lookup for /cache1, 00/, 01/, and then the file 000102) which takes
time. You have to do a linear search inside the directory in order
to find the file you're after. And if you have 2 million files (thats
a standard squid box these days), even with a small (10%) frequently
used subset of these files, thats 200,000 files thrashing your namecache.
Its not pretty, which is why I'm working on alternatives. :-)
One of the alternatives which Robert has mentioned is IFS. It is designed
for applications like the above. Instead of requiring a filename, you
simply index each file in FFS using the inode number. It is not committed
right now, but I'm hoping it will provide a solution to problems like
this.
You can find the IFS code http://www.freebsd.org/~adrian/ .
Adrian
--
Adrian Chadd Build a man a fire, and he's warm for the
<[EMAIL PROTECTED]> rest of the evening. Set a man on fire and
he's warm for the rest of his life.
To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-hackers" in the body of the message