Method level profiling of newly launched JVM

142 Views Asked by At

In my application, a new JVM is launched when ever a new resource is created. I am able to profile the newly launched JVM by connecting it in yourkit.

Right now I am able to connect to JVM only after it is ready and after that I am able to profile it but i want to profile the JVM methods while is is coming up i.e profile the methods calls of the JVM while it is initializing.

Is there any way i can achieve this?

Reason for this is, some methods which are only invoked during initialization are causing some problem and those can't be profiled once the JVM is created and is ready.

Thanks

2

There are 2 best solutions below

1
On

You want to do a remote debugging session on code that runs in the initial few seconds of your app being launched.

A problem that you can run into when attempting to do this is that since the code runs right in the beginning, the JVM may rush past it before you have had a chance to attach a debugger via Eclipse and set your break points.

The solution is to setup your JVM/debugging config so that it is set to suspend at startup.

A typical way to setup remote debugging is to use the following JVM argument in the code used to launch your application so that a debugger can later attach itself to port 8000.

-Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8000

Infact this is what Eclipse does when you launch an app in debug mode rather than normal mode. It adds this line in the JVM arguments used when launching your application.

Note the suspend=n. If that is set to y, the JVM will suspend on startup. It will wait for a debugger to attach to it and release it before it will proceed.

So using the suspend flag, our problem is solved.

Source: http://www.onkarjoshi.com/blog/224/how-to-suspend-vm-on-startup-when-remote-debugging-your-java-app/

0
On

If under "JVM methdos" you mean Java method which are being called on JVM initialization, then you are able to do it with yourkit. You have to:

After that you should see "early" call in YourKit UI after connection.