Date: Mon, 24 Dec 2007 10:56:45 -0700 From: Brett Glass <brett@lariat.net> To: Scott Long <scottl@samsco.org> Cc: stable@freebsd.org Subject: Re: SMP on FreeBSD 6.x and 7.0: Worth doing? Message-ID: <200712241756.KAA21950@lariat.net> In-Reply-To: <476FE868.8080704@samsco.org> References: <200712220531.WAA09277@lariat.net> <476FBED0.2080400@samsco.org> <200712241549.IAA19650@lariat.net> <476FDA10.4060107@samsco.org> <200712241653.JAA20845@lariat.net> <476FE868.8080704@samsco.org>
next in thread | previous in thread | raw e-mail | index | archive | help
At 10:12 AM 12/24/2007, Scott Long wrote: >It's not the same kind of hashing. The kind of "hashing" that squid >does on the filesystem is sub optimal for UFS performance. Squid doesn't do any "hashing" on the file system, as far as I know. It does, of course, have a hashed directory of cached Web objects. What it does, however, is lay out files and subdirectories so that there are no more than 256 entries in each directory. (The top level directory usually has only 16 subdirectories in it.) What I am saying is that by keeping directory size down and using hexadecimal numbers as the file names, the Squid storage conventions will likely allow the UFS hashing scheme to work very well -- possibly optimally. Which isn't a surprise, because they were designed with UFS in mind. >It sounds like you're pretty convinced you know what the problem is. Again, I'd have to instrument either the FreeBSD kernel or Squid to be 100% sure. But it APPEARS that it's a problem with large numbers of threads trying to do file I/O simultaneously and blocking. (Aside: I wish that Squid used FreeBSD's sendfile(2) API once it got past the headers and was just streaming out a cached page. I suspect that this would make delivery of cache hits a lot more efficient, because sendfile(2) does "zero copy" transfers and works entirely within the kernel.) >For others who might want help with this, tweaking >vfs.ufs.dirhash_maxmem is what is needed. A bit of a balancing act is >needed if you're on i386 since you'll risk exhausting KVA unless you >also tweak KVA_PAGES. If you'd like, I can reassemble the system and try this. What would your suggested values for these tunables be? --Brett
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200712241756.KAA21950>