Comments
Richard Davies wrote: The UK has a good crop of technology pioneers in cloud computing - for example ElasticHosts, FlexiScale, Flexiant, OnApp - and also some strong government initiatives such as G-Cloud. We will have to see whether this kind of technical leadership converts into swift mass-market adoption or not.
Cloud Expo on Google News

SYS-CON.TV
Cloud Expo & Virtualization 2009 East
PLATINUM SPONSORS:
IBM
Smarter Business Solutions Through Dynamic Infrastructure
IBM
Smarter Insights: How the CIO Becomes a Hero Again
Microsoft
Windows Azure
GOLD SPONSORS:
Appsense
Why VDI?
CA
Maximizing the Business Value of Virtualization in Enterprise and Cloud Computing Environments
ExactTarget
Messaging in the Cloud - Email, SMS and Voice
Freedom OSS
Stairway to the Cloud
Sun
Sun's Incubation Platform: Helping Startups Serve the Enterprise
POWER PANELS:
Cloud Computing & Enterprise IT: Cost & Operational Benefits
How and Why is a Flexible IT Infrastructure the Key To the Future?
Click For 2008 West
Event Webcasts
JProbe Profiler 1.1.1 by KL Group, Inc.
JProbe Profiler 1.1.1 by KL Group, Inc.

The Java language removes several problem areas for developers, compared to C++ development, by its elimination of memory allocation and pointer management. While this generally makes Java programs more stable than their C++ brethren, it can often lead to the misconception that Java programs don't need to be optimized or profiled. Nothing could be further from the truth, especially when you consider that Java is being used to build enterprise-class applications, which require high performance. KL Group has built a strong reputation for supplying Java components to many of the leading software vendors, and they have extended their Java presence with JProbe Profiler.

Product Installation
KL Group delivers the software directly from their Web site for download, as well as offers the software on CD-ROM. JProbe is available for Windows 95/NT and installs with an InstallShield executable. I was able to get the software installed in a matter of minutes, and the complete installation required only about 14 MB of disk space. JProbe requires the JDK 1.1.5 version to run, but you can profile any application that was written for either the JDK 1.0 or 1.1 series virtual machine. If you have already installed the JDK 1.1.5 virtual machine, you'll still need to install the version that comes with JProbe, since it's a specialized version of the standard 1.1.5 JDK virtual machine. The runtime environment for JProbe allows you to set CLASSPATH definitions for individual programs as needed, so it's not necessary to modify your Java development environment to get started.

Uncovering Performance Bottlenecks
Java as both a platform and a language offers a number of advantages in terms of portability and standardization. Programmers across the globe are migrating to Java from a variety of other languages and platforms. For many of us the move to Java may also be our first real, hard-core experience with object-oriented programming.

As a result, the programs you write may have hidden performance bottlenecks that slow down processing and eat memory. KL Group's JProbe is designed to uncover these hidden performance anomalies including such common problems as excessive object creation, method calling and thread creation, and inefficient memory usage. The Profiler collects timing information and memory data as you run your Java programs, and JProbe supports most of the leading Java development environments. I used Oracle's JDeveloper product to create a few sample Java programs for testing. Once you've compiled your code in your favorite development tool, start the Profiler and select the "Run" menu. I was quickly able to search for possible performance problems in my code by using the "Memory Usage Monitor," as shown in Figure 1.

The memory monitor charts memory as it's used by the program and is generally the first place you start when you use the Profiler. KL Group includes a number of sample program runs with JProbe, and I'd advise you to start by using these examples with the Profiler's online help to get an overview of the Profiler's capabilities. You have a choice of running a program through to conclusion as one long run, or you can divide the performance data into specific chunks by using "snapshots." I found the snapshots invaluable as a tool for comparing the first pass of a program with subsequent executions through the same set of code. They were especially helpful tracking down problems with event-driven code. I was able to use the memory monitor to drill down into details of my code quickly and easily. The snapshots can be used to track calling relationships, as shown in Figure 2.

You can see in the diagram that the profiler can show a hierarchical display of method calls, which can help you expose the most expensive methods. If you need to, you can click down to the source code directly from the diagram, and the graphical interface uses colors to highlight the more expensive method calls.

If you choose to view the source within the Profiler, you can see how much resource is used by each routine in a panel next to the source window. The Profiler makes it easy to shift between multiple snapshots, and you can save the entire set of snapshots and program definitions for reuse at a later time. I was impressed with how quickly I was able to find problems in my own programs, but I'll take a pass on telling you just how bad my coding actually was before JProbe got ahold of it!

Performance and Usability
KL Group claims to have improved the performance of JProbe Profiler by a factor of 10 with this release. I didn't test any large or long-running programs with the Profiler, but JProbe ran briskly enough on my development platform. I couldn't see any easy way to test programs out in batch, although I was able to save test sessions for later analysis, and you can save programs for reexecution as well. The online documentation with JProbe Profiler is adequate for using the product, but it's a little weak in the area of interpretation. The help files have a tendency to expect that many of the performance numbers will be self-explanatory, and novice programmers may find that it'll take some practice to get a handle on interpreting results. I'd encourage you to make use of the tutorial and sample files before tackling any of your own code.

Final Thoughts
There are several products on the market that purport to provide performance profiling for Java. However, when I quickly searched the various Java newsgroups for user opinions, I found that many programmers had good things to say about JProbe Profiler. One programmer in particular claimed that JProbe had helped him to get a hundred-fold improvement in performance. My informal Web survey seemed to indicate that JProbe is clearly the leader in Java profilers, and from my brief experience with the product, I'd be inclined to agree.

About Jim Milbery
Jim Milbery is a Vice President with William Blair Capital Partners, a venture capital firm based in Chicago. He has over 19 years of experience in application development and relational databases. He is the former applications editor for "Wireless Business and Technology", the past product reviews editor for Java Developer Journal and the author of "Making the Technical Sale". Jim can be reached at jmilbery@williamblair.com, or via the company web site at http://www.wbcapitalpartners.com

In order to post a comment you need to be registered and logged in.

Register | Sign-in

Reader Feedback: Page 1 of 1

Latest Cloud Developer Stories
Swisscom, the Swiss telecom, is going into the cloud business. Its subsidiary Swisscom IT Services AG has signed up with Red Hat as a Certified Cloud Provider and launched a public cloud Infrastructure-as-a-Service (IaaS) cloud targeting enterprise-class customers primarily in ...
Apache Deltacloud, the Red Hat-contributed ReSTful API that abstracts differences between clouds so services on any cloud can be managed – provided of course there’s a driver – has graduated from the Apache Foundation’s incubator and is now a full-fledged Top-Level Project (TLP)....
In a surprise move on Tuesday, January 10, Oracle wheeled out its Big Data Appliance. That’s the one it said in October would be ready sometime in the first half. Only nobody believed it meant early in the first half. Heck, it’s not even clear anybody thought Oracle could make ...
Rackspace Hosting, the service leader in cloud computing, on Thursday announced its acquisition of SharePoint911, an industry leader in SharePoint consulting, training, and "JumpStart" services within SharePoint. The unification of both companies provides capabilities to deliver ...
CloudLinux, Inc., on Thursday released CafeFS 3, a virtualized file system for shared hosters that cages each customer within its own virtualized file system. CageFS becomes part of CloudLinux OS at no additional charge. CloudLinux OS, the only commercially-supported Linux OS m...
Subscribe to the World's Most Powerful Newsletters
Subscribe to Our Rss Feeds & Get Your SYS-CON News Live!
Click to Add our RSS Feeds to the Service of Your Choice:
Google Reader or Homepage Add to My Yahoo! Subscribe with Bloglines Subscribe in NewsGator Online
myFeedster Add to My AOL Subscribe in Rojo Add 'Hugg' to Newsburst from CNET News.com Kinja Digest View Additional SYS-CON Feeds
Publish Your Article! Please send it to editorial(at)sys-con.com!

Advertise on this site! Contact advertising(at)sys-con.com! 201 802-3021

SYS-CON Featured Whitepapers
ADS BY GOOGLE

Breaking Cloud Computing News

BEACHWOOD, Ohio, Feb. 16, 2012 /PRNewswire/ -- DDR Corp. (NYSE: DDR) today announced operating re...