From owner-freebsd-current@FreeBSD.ORG Thu Feb 28 01:27:01 2008 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id C10CA1065670 for ; Thu, 28 Feb 2008 01:27:01 +0000 (UTC) (envelope-from davids@webmaster.com) Received: from mail1.webmaster.com (mail1.webmaster.com [216.152.64.169]) by mx1.freebsd.org (Postfix) with ESMTP id A08C48FC1F for ; Thu, 28 Feb 2008 01:27:01 +0000 (UTC) (envelope-from davids@webmaster.com) Received: from however by webmaster.com (MDaemon.PRO.v8.1.3.R) with ESMTP id md50001914782.msg for ; Wed, 27 Feb 2008 17:18:04 -0800 From: "David Schwartz" To: "FreeBSD Current" Date: Wed, 27 Feb 2008 17:16:35 -0800 Message-ID: MIME-Version: 1.0 Content-Type: text/plain; charset="ISO-8859-15" Content-Transfer-Encoding: 7bit X-Priority: 3 (Normal) X-MSMail-Priority: Normal X-Mailer: Microsoft Outlook IMO, Build 9.0.6604 (9.0.2911.0) In-Reply-To: <47C5E204.9080003@rfc2549.org> X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.3198 Importance: Normal X-Authenticated-Sender: joelkatz@webmaster.com X-Spam-Processed: mail1.webmaster.com, Wed, 27 Feb 2008 17:18:04 -0800 (not processed: message from trusted or authenticated source) X-MDRemoteIP: 206.171.168.138 X-Return-Path: davids@webmaster.com X-MDaemon-Deliver-To: freebsd-current@freebsd.org X-MDAV-Processed: mail1.webmaster.com, Wed, 27 Feb 2008 17:18:06 -0800 Subject: RE: Specific Swap Usage X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list Reply-To: davids@webmaster.com List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 28 Feb 2008 01:27:01 -0000 > is there any way to look what programs are swapped out and how much > memory they use? Looking at SIZE in top is just a wild guess. There are really only two reasons SIZE might not do what you want, and it's quite possible neither applies. In which case, you should use SIZE. 1) A process may have mappings that don't use nearly as much physical memory or swap space as the mapping might suggest. Programs that 'mmap' large files or use weird sparse arrays may do this. If you know a program doesn't do this, this isn't a problem. 2) SIZE doesn't distinguish between physical memory and swap. But there's really no logical reason you should care. The OS can always put something in swap in physical memory and something in physical memory in swap. What you are really running out of is swap plus physical memory anyway. (For example, if a program relinquished 16MB of physical memory, that would help you at least as much as it relinquishing 16MB of swap.) > One server > here grows in swap usage and panics eventuelly when all swap is usage. > Swap usage is growing slowly (100 MB /week ) but it is growing and see > no way to get what really uses swap :( (Read man ps three times > already :/) Is SIZE rising for this process too? Odds are it is, and you should try to figure out why. If it turns out to be something harmless, that's fine. But odds are very high this will point the way to your problem. If all else fails, you can parse /proc//map to figure out what mappings the process has and what type they are. This will allow you to subtract mmap'ed files that use vm space but not swap+physmem. DS