loosejar is a simple Java Agent that can be used to discover unnecessary jars lying on application classpath. It performs per classloader JVM heap analysis and displays its results. The results can be extracted in the form of comma separated values (csv) or the default verbal mechanism. loosejar can be safely used during development, QA, UAT or even in production as it doesn't modify the state of the JVM at all and adds no overhead. loosejar can also extract the results into a file.
The usage is very simple:
- Start your application or application server with
-javaagent:loosejar.jar
flag (loosejar.jar should obviously point to the correct path of the actual jar) with or without the configuration properties.S - Exercise your application to make sure that the classes get loaded into the JVM.
- Get loosejar analysis results via JMX console (open jconsole and run
com.googlecode.loosejar.LooseJarMBean#summary()
inMBeans
folder) or on application shutdown.
loosejar can only be used on Java 1.5 or higher JVMs.
loosejar can be configured using java system properties. Following are the configurations available in loosejar
loosejar.format
- This is a non mandatory property which can be used to specify the output format, supports values csv or verbal for now. This configuration also affects the output format of results extracted via JMX console.loosejar.outputFile
- This is a non mandatory property which can be used to extracts the results to the file. If this option is not specified loosejar prints results on to console (System.out). This configuration is only applied on application shutdown.
- loosejar 1.0.1 has been released!
- loosejar 1.2.0 has been released. It includes support for Java 9+ versions.