On Thu, 2007-10-18 at 08:04 -0500, Gary Mills wrote: > Here's a suggestion on the cause: > > The root problem seems to be an interaction between Solaris' concept > of global memory consistency and the fact that Cyrus spawns many > processes that all memory map (mmap) the same file. Whenever any > process updates any part of a memory mapped file, Solaris freezes all > of the processes that have that file mmaped, updates their memory > tables, and then re-schedules the processes to run. When we have > problems we see the load average go extremely high and no useful work > gets done by Cyrus.
that sounds like a somewhat mangled description of the cross-calls done to invalidate the TLB on other processors when a page is unmapped. (it certainly doesn't happen on *every* update to a mapped file). from grepping the source code it looks like cyrus is both multithreaded and a heavy user of munmap. - Bill _______________________________________________ zfs-discuss mailing list zfs-discuss@opensolaris.org http://mail.opensolaris.org/mailman/listinfo/zfs-discuss