From owner-freebsd-stable@FreeBSD.ORG Tue Oct 16 01:13:18 2007 Return-Path: Delivered-To: freebsd-stable@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id D973416A41B for ; Tue, 16 Oct 2007 01:13:18 +0000 (UTC) (envelope-from cliftonr@lava.net) Received: from malasada.lava.net (malasada.lava.net [64.65.64.17]) by mx1.freebsd.org (Postfix) with ESMTP id AE3CC13C481 for ; Tue, 16 Oct 2007 01:13:18 +0000 (UTC) (envelope-from cliftonr@lava.net) Received: by malasada.lava.net (Postfix, from userid 102) id E4A81153882; Mon, 15 Oct 2007 14:48:33 -1000 (HST) Date: Mon, 15 Oct 2007 14:48:33 -1000 From: Clifton Royston To: Alfred Perlstein Message-ID: <20071016004833.GB18975@lava.net> Mail-Followup-To: Alfred Perlstein , William LeFebvre , freebsd-stable@freebsd.org References: <008801c80e66$7be49490$0c00a8c0@Artem> <471367F2.7050303@lefebvre.org> <20071015220836.GO31826@elvis.mu.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20071015220836.GO31826@elvis.mu.org> User-Agent: Mutt/1.4.2.2i Cc: William LeFebvre , freebsd-stable@freebsd.org Subject: Re: Question about 'top' values on memory usage X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 16 Oct 2007 01:13:18 -0000 On Mon, Oct 15, 2007 at 03:08:36PM -0700, Alfred Perlstein wrote: > * William LeFebvre [071015 06:49] wrote: > > > > Unfortunately, freebsd does not appear to track the amount of shared > > virtual memory for each process. It could be obtained by walking > > through all the pages in a process's vm map, but that would really slow > > top down. I don't know of any freebsd utility that would give that > > information for an individual process. But hey, if it's out there > > somewhere where it is easy to grab, I would be very happy to add it to top. > > Or this could be properly accounted for when the map is updated? > > > Personally, based on my experience, I would be more concerned with the > > amount of available cpu cycles than memory. In my experience, once you > > run out of idle time on a web server you have exceeded its capacity to > > serve pages. In that situation it doesn't matter how many httpd > > processes there are, the system is still not able to keep up with > > demand. And that will probably happen before the system starts > > thrashing from limited memory. > > Bill, I would have to differ with you based on personal experience, > I've almost never run out of cpu on a webserver, typically it's the > RAM that gets blown out. Once the server starts to page, you typically > wind up with a cascade failure and the box just goes ... belly up. IME, it really depends mostly what kind of content you're serving; I've seen either one, or disk, be the problem. Serving mostly static pages? Don't worry about CPU, it'll be the RAM. Naive database search, not caching the results? You may get killed on disk I/O. If you're serving some kind of computationally "expensive" content via a CGI and the site gets hit, then it'll run out of CPU. All in all I would guess the latter's much rarer, assuming you're using a well configured webserver built with an appropriate client-connection service model. OTOH, if you can guess the process limits correctly, you can usually set them with a safety margin such that the machine won't hit the number of processes to force it into paging; it'll be unresponsive to clients above its limit, but continue to respond adequately to the clients which succeed in connecting. All IMHO. -- Clifton -- Clifton Royston -- cliftonr@iandicomputing.com / cliftonr@lava.net President - I and I Computing * http://www.iandicomputing.com/ Custom programming, network design, systems and network consulting services