Mar 19, 2010

Java Execution Time Measurement Library - JETM

The first part of analyzing the applications with bad performance is to identify the code fragments which are causing the issue. In order to identify them, we will need to find out the execution timings across different pieces of the application. 

To achieve this, we follow one of the following approaches

  • Profile the application using a java profiler.
  • Write log statements to determine the execution times

Profilers can give fine grained information regarding the memory allocation, execution paths and garbage collection behavior.  Profilers add overhead to the execution and often make the applications slower.  So this cannot be used in a real production environment.

The second approach of writing log statements is a time consuming and requires lot of changes to your source code.  This process can be reduced by writing aspect classes which will include log statements and apply advice on various point cuts (AOP approach)

But we always wish that it will be useful if we can have a library which will help us in measuring the execution times with little or no changes to our source code with a very less overhead. 

While exploring this, I have found out that there is a Java Execution Time Measurement Library which perfects fits in this area.

Features of this library

  • Very light weight and free library. 
  • Very low overhead
  • Can be used declaratively or programmatically
  • Can record the data in a flat or nested manner
  • No VM level instrumentation needed
  • Built in http console which can used to view the execution timings in the form of a report
  • Specify the classes (expressions allowed) to be monitored

Best part of it is that we can easily integrate this if you are already using spring framework in your application.  You can make few changes in your spring context files (in a declarative fashion of course) and add one jetm.jar.  You are on your way to collecting the execution times of various classes and methods in your application.

Go ahead and try it out yourself. 

URL: http://jetm.void.fm/

Related Posts

Related Posts:

  • Generating Pie Charts in JavaIntroductionEasyCharts is 100% Java based charting library that enables the user to embed charts in the java applications and web pages with very little coding effort. The library contains AWT based chart components, applets … Read More
  • Garbage Collection and Heap Memory Management with JavaThis article has been prepared to understand the process of Garbage Collection. This includes how the JVM carry out the memory reclaim process from heap. This document also covers the JVM and Tomcat server settings and precau… Read More
  • Comparison of Enhancements in Java 1.4, Java 1.5 and Java 6.0What is Java?Java is a programming language expressly designed for use in the distributed environment of the Internet. It was designed to have the "look and feel" of the C++ language, but it is simpler to use than C… Read More
  • Case Study on High CPU utilization by Java GUI Based ApplicationCase Study: Increase in CPU usage for a Multi-Thread Java Application. Problem Description: A multi-threaded GUI based Java application running on a Solaris machine caused a significant rise in the CPU usage leading to slow… Read More
  • Generating Pie Charts in JavaIntroductionEasyCharts is 100% Java based charting library that enables the user to embed charts in the java applications and web pages with very little coding effort. The library contains AWT based chart components, applets … Read More

0 comments:

Text Widget

Copyright © 2025 Vinay's Blog | Powered by Blogger

Design by | Blogger Theme by