How's linux-ibm-jdk14 in the memory footprint department?

Nicolas Gieczewski nicolas at nixsoftware.com
Fri Dec 12 07:14:13 PST 2003


Many thanks to Thomas and Dan for their replies. The actual RSS has always been around 16 MB, but I was thinking the difference between VSZ and RES was going into the swap area. Obviously a lack of knowledge on memory management on my part. I'll have to read some stuff on this.

Thanks again,

Nick


----- Original Message ----- 
From: "Sparrevohn, Thomas" <thomas.sparrevohn at eds.com>
To: "'Dan Nelson'" <dnelson at allantgroup.com>; <freebsd-java at freebsd.org>
Sent: Friday, December 12, 2003 08:02
Subject: RE: How's linux-ibm-jdk14 in the memory footprint department?


Yes - I looked at It and it seems that while it uses a large address space the RSS stays around 21MB-41MB for j2ee as an example. There are a potential problem with the way it is done that would occur if a very large library was used. Has anybody looked at deferred loads?


-----Original Message-----
From: owner-freebsd-java at freebsd.org [mailto:owner-freebsd-java at freebsd.org] On Behalf Of Dan Nelson
Sent: 11 December 2003 23:41
To: freebsd-java at freebsd.org
Subject: Re: How's linux-ibm-jdk14 in the memory footprint department?


Nicolas Gieczewski wrote:
> Thanks for the suggestion. I could only get it down to about 152 MB
> with an initial heap size of 8 MB and a maximum size of 16 MB. I 
> believe this is probably too small, though (actually, I have no idea, 
> guess I'll have to see how often the GC is kicking in). Even though 
> not all of the 152 MB (or 203 MB, for that matter) are in main memory 
> at any given time, don't they become unavailable to the OS, anyway? 

Definitely not.  Note that java will mmap any .jar files you use, so 
things like rt.jar will add 30MB to your process size right off the bat. 
    Very little of it will actually get paged in from disk, though, and 
what little does get paged in will be shared across all java processes. 
  I don't know where the rest of the 100 or so MB is going, but the most 
important thing to watch is the RSS value and whether you are swapping 
or not.  I did a simple test of running /usr/local/jdk1.4.2/bin/jar on a 
little file and pausing it so I could see the stats in top:

   PID USERNAME  PRI NICE   SIZE    RES STATE TIME   WCPU    CPU COMMAND
24511 dan        97    0   198M  7460K STOP  0:00  0.00%  0.00% jar

Note that the process space is almost 200MB, but really under 8MB is 
being used.  My guess is the extra space has something to do with 
threads, or maybe a sparse array was allocated (like what rpc.statd does).


-- 
Dan Nelson
dnelson at allantgroup.com



More information about the freebsd-java mailing list