From owner-freebsd-hackers Thu Jan 30 11:41:39 2003 Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id DFC0737B401 for ; Thu, 30 Jan 2003 11:41:37 -0800 (PST) Received: from apollo.backplane.com (apollo.backplane.com [216.240.41.2]) by mx1.FreeBSD.org (Postfix) with ESMTP id 70D4F43F43 for ; Thu, 30 Jan 2003 11:41:37 -0800 (PST) (envelope-from dillon@apollo.backplane.com) Received: from apollo.backplane.com (localhost [127.0.0.1]) by apollo.backplane.com (8.12.6/8.12.6) with ESMTP id h0UJfb0i089231; Thu, 30 Jan 2003 11:41:37 -0800 (PST) (envelope-from dillon@apollo.backplane.com) Received: (from dillon@localhost) by apollo.backplane.com (8.12.6/8.12.6/Submit) id h0UJfa0e089230; Thu, 30 Jan 2003 11:41:36 -0800 (PST) Date: Thu, 30 Jan 2003 11:41:36 -0800 (PST) From: Matthew Dillon Message-Id: <200301301941.h0UJfa0e089230@apollo.backplane.com> To: James Gritton Cc: freebsd-hackers@FreeBSD.ORG Subject: Re: What's the memory footprint of a set of processes? References: <20030130064448.GA7258@HAL9000.homeunix.com> <200301300719.h0U7JOfI086054@apollo.backplane.com> Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG I just had another idea on how you could do this. It's actually not all that complex. All you do is collect statistics on each VM object individually (whether shadow or top level or whatever). e.g. Resident page count, swap usage. Then you collect a list of VM objects associated with a process, regardless of HOW they are associated. Recurse through the vm_map_entry's and the shadow chains to get the list. Then you simply group all the processes which share VM objects together and report statistics on a group-by-group basis rather then on a process-by-process basis. You won't know what an individual process uses but you know exactly what the group of processes use in aggregate. Groups of processes will tend to form due to fork()ing, processes sharing memory via SysV shared memory, and processes that happen to be mapping the same file (vnode). You will get accurate memory use for each group. -Matt : Actually, that's just the sort of thing I'm looking for. The shared case :may be relatively rare, but it tends to be extreme: the processes that use :the most memory seem to be the ones that fork the most - database servers, :java, etc. The point of this whole thing is an attempt to limit the memory :use of a user (instead of a process), but I don't want to penalize such :sharing. : :.. : That's OK - resident count is what I'm interested in. That, and the swap :approximation (which should suffice) you mentioned for non-vnode objects. : :- Jamie To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message