Christoph Lameter wrote: > On Wed, 24 Jan 2007, Vaidyanathan Srinivasan wrote: > >> With your patch, MMAP of a file that will cross the pagecache limit hangs the >> system. As I mentioned in my previous mail, without subtracting the >> NR_FILE_MAPPED, the reclaim will infinitely try and fail. > > Well mapped pages are still pagecache pages. >
Yes, but they can be classified under a process RSS pages. Whether it is an anon page or shared mem or mmap of pagecache, it would show up under RSS. Those pages can be limited by RSS limiter similar to the one we are discussing in pagecache limiter. In my opinion, once a file page is mapped by the process, then it should be treated at par with anon pages. Application programs generally do not mmap a file page if the reuse for the content is very low. >> I have tested your patch with the attached fix on my PPC64 box. > > Interesting. What is your reason for wanting to limit the size of the > pagecache? 1. Systems primarily running database workloads would benefit if background house keeping applications like backup processes do not fill the pagecache. Databases use O_DIRECT and we do not want the kernel to even remove cold pages belonging to that application to make room for pagecache that is going to be used by an unimportant backup application. The objective is to have some limit on pagecache usage and make the backup application take all the performance hit and have zero impact on the main database workload. Solutions: * The backup applications could use O_DIRECT as well, but this is not very flexible since there are restrictions in using O_DIRECT. Please review http://lkml.org/lkml/2007/1/4/55 for issues with O_DIRECT * Improve fadvice to specify caching behavior. Rightnow we only model the readahead behavior. However this would need a change in all applications and more command line options. * The technique we are discussing right now can serve the purpose 2. In the context of 'containers' and per container resource management, there is a need to restrict resources utilized by each of the process groups within the container. Resources like CPU time, RSS, pagecache usage, IO bandwidth etc may have to be controlled for each process groups. Some of today's open virtualisation solutions like UML instances, KVM instances among others also have a need to control CPU time, RSS and (unmapped) pagecache pages to be able to successfully execute commercial workloads within their virtual environments. Each of these instances are normal Linux process within the host kernel. --Vaidy - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/