Hello Neil, > Leal, > > ZFS uses the DNLC. It still provides the fastest > lookup of <directory, name> to vnode.
Ok, so the whole concept remains true? We can tune the DNLC and expect the same behaviour on ZFS? > The DNLC is kind of LRU. An async process will use a > rotor to move > through the hash chains and select the LRU entry but > will select first > negative cache entries and vnodes only referenced by > the DNLC. > Underlying this ZFS uses the ZAP and Fat ZAP to store > the mappings. Here i did not understand very well. You are saying that ZFS uses DNLC just for one level? > > ZFS does not use the 2nd level DNLC which allows > caching of directories. > This is only used by UFS to avoid a linear search of > large directories. What is the ZFS way here? One of the points of my question is exactly that... in an environment with many directories with *many* files, i think ZFS would has the *same* problems too. So, having directories cache on DNLC could be a good solution. Can you explain how ZFS handles the performance in directories with hundreds of files? There is a lot of docs around UFS/DNLC, but for now i think the only doc about ZFS/ARC and DNLC is the source code. ;-) > > Neil. Thanks a lot! I was thinking in tune DNLC to have as many metadata (directories and files) as i can, to minimize lookups/stats and etc (in NFS there is a lot of getattr ops). So we could have *all* the metadata cached, and use what remains in memory to cache data. Maybe that kind of tuning would be usefull for just a few workloads, but could be a *huge* enhancement for that workloads. Leal -- posix rules -- [http://www.posix.brte.com.br/blog] > > On 10/30/08 04:50, Marcelo Leal wrote: > > Hello, > > In ZFS the DNLC concept is gone, or is in ARC too? > I mean, all the cache in ZFS is ARC right? > > I was thinking if we can tune the DNLC in ZFS like > in UFS.. if we have too *many* files and > > directories, i guess we can have a better > performance having all the metadata cached, and that > > is even more important in NFS operations. > > DNLC is LRU right? And ARC should be totally > dynamic, but as in another thread here, > > i think reading a *big* file can mess with the > whole thing. Can we hold an area in memory > > for DNLC cache, or that is not the ARC way? > > > > thanks, > > > > Leal. > _______________________________________________ > zfs-discuss mailing list > zfs-discuss@opensolaris.org > http://mail.opensolaris.org/mailman/listinfo/zfs-discu > ss -- This message posted from opensolaris.org _______________________________________________ zfs-discuss mailing list zfs-discuss@opensolaris.org http://mail.opensolaris.org/mailman/listinfo/zfs-discuss