GC Timestamps in Java 6
Y Srinivas Ramakrishna
Y.S.Ramakrishna at Sun.COM
Thu May 29 17:36:03 UTC 2008
Just wanted to add the probably somewhat obvious footnote that even for stop-world
phases what's reported is process-virtual time; of course in that case the work done by
other threads in the process is a negligible fraction since most of the mutator
threads are stopped for most of that time-window. However, mutator threads executing
native code (and therefore not stopped) or the so-called "watcher thread"
running in short bursts during a long collection, and/or some non-trivial work
done by the "coordinating" vm thread (rather than the gc worker threads) might
sometimes throw off your expectations by a bit.
-- ramki
----- Original Message -----
From: Y Srinivas Ramakrishna <Y.S.Ramakrishna at Sun.COM>
Date: Thursday, May 29, 2008 8:50 am
Subject: Re: GC Timestamps in Java 6
To: Nicolas Michael <email at nmichael.de>
Cc: hotspot-gc-dev at openjdk.java.net
> You are right that this represents the process virtual time (and
> elapsed time)
> rather than lwp-virtual time. I agree that for the concurrent phases reporting
> lwp-virtual time over the lwp's doing the concurrent gc work would be
> useful.
>
> -- ramki
>
> ----- Original Message -----
> From: Nicolas Michael <email at nmichael.de>
> Date: Thursday, May 29, 2008 2:29 am
> Subject: GC Timestamps in Java 6
> To: hotspot-gc-dev at openjdk.java.net
>
>
> > Hi,
> >
> > you have introduced some additional timestamps in the gc logs with
> > Java 6,
> > showing cpu time (user and system) as well as elapsed time. When I
> ran
> > some CMS
> > tests where I changed the number of CMS threads, I've noticed that
> > those numbers
> > don't show what I originally expected...
> >
> > For a STW collection, this new output is quite nice:
> > 966.697: [GC 966.698: [ParNew: 260292K->65536K(262144K), 0.1426038 secs]
> > 1090657K->898209K(1368064K), 0.1429749 secs] [Times: user=1.88 sys=0.06,
> > real=0.14 secs]
> > The collection took 0.14 secs, and the ParNew threads consumed 1.88+0.06=1.94
> > seconds cpu time. With 16 ParNew threads that I had configured, each
> single
> > thread was therefore on a cpu for most of the time (they consumed
> 1.94
> > out of
> > 16*0.14=2.24 theoretically possible cpu seconds). That's nice to know!
> >
> > However, for concurrent activities, this output is a little confusing:
> > 2319.981: [CMS-concurrent-mark: 3.487/3.487 secs] [Times: user=54.12
> sys=0.78,
> > real=3.49 secs]
> > The concurrent mark took 3.49 seconds, ok. Now I would expect the
> > "user" and
> > "sys" times to reflect the cpu time consumed for concurrent marking
>
> > (the sum
> > over all parallel CMS threads). In this example, I had 8 parallel
> CMS
> > threads
> > configured (plus the "coordinator" CMS thread). But 9 threads cannot
>
> > consume 55
> > cpu seconds within 3.5 real seconds. So I guess this cpu time
> reported
> > as "user"
> > and "sys" is consumed by *all* threads of the JVM, including the mutator
> > threads. Which would make sense (the numbers would fit), but is a rather
> > meaningless information...
> >
> > Probably it is intended that way. But I think those times would be
> > more usefull
> > if they reflected *only* the gc activities. When I look at a gc log,
> I
> > would
> > like to see how much time (elapsed as well as cpu cycles) are spent
>
> > for *garbage
> > collection*, without cpu time spent for my mutator threads.
> >
> > What do you think?
> >
> > Nick.
> >
> > PS: Thanks Tony for pointing me to this discussion
> > list!
> >
More information about the hotspot-gc-dev
mailing list