Setting Goals

Before starting on performance testing, it is necessary to set non-functional requirements to specify load and response times. If you are migrating from an existing system, make sure that response times are similar to your current production values. For load, it is best to take the current peak load and double it. Doing so ensures that the website can continue to perform well as it grows.

Tools

There are many commercially available performance testing tools on the market. When running a load generating tool, it is important to ensure that the computers which are performing the tests have sufficient network bandwidth. Otherwise, once the test machine reaches the limits of its connection, no additional load is generated on the environment under test.

Testing Tools

  • Adobe’s Tough Day tool can be used to generate load on AEM instances and collect performance data. Adobe’s AEM engineering team actually uses the tool to do load testing of the AEM product itself. The scripts executed in Tough Day are configured via property files and JMX XML files. For more information, see the Tough Day documentation.

  • AEM provides out of the box tools to quickly see problematic queries, requests, and error messages. For more information, see the Diagnosis Tools section of the Operations Dashboard documentation.

  • Apache provides a product called JMeter that can be used for performance and load testing, and functional behavior. It is open-source software and free to use, but has a smaller feature set than enterprise products and a steeper learning curve. JMeter can be found on Apache’s website at https://jmeter.apache.org/

  • Load Runner is an enterprise grade load testing product. A free evaluation version is available. More information can be found at https://www.microfocus.com/en-us/portfolio/performance-engineering/overview

  • Website load testing tools like Vercara can also be used.

  • When testing mobile or responsive websites, a separate set of tools must be used. They work by throttling network bandwidth, simulating slower mobile connections like 3G or EDGE. Among the more widely used tools include the following:

    • Network Link Conditioner - it provides an easy to use UI and works at a fairly low level on the networking stack. It includes versions for OS X and iOS;
    • Charles - a web debugging proxy application that in addition to several other uses, provides network throttling. Versions are provided for Windows, OS X, and Linux®.

Optimization Tools

Monitoring

The Monitoring Performance documentation is a good resource for tools and methods that can be used to diagnose issue and pinpoint areas for tuning.

Developer Mode in Touch UI

One of the new features in AEM 6’s touch UI is the Developer Mode. Just as authors can switch between edit and preview modes, developers can switch to developer mode in the author UI. Doing so lets you see the render time for each of the components on the page and to see stack traces of any errors. For more information on developer mode, see this CQ Gems presentation.

Using the rlog.jar to read the request logs

For a more comprehensive analysis of the request logs on an AEM system, rlog.jar can be used to search through and sort the request.log files that AEM generates. This jar file is included with an AEM installation in the /crx-quickstart/opt/helpers folder. For more information on rlog tool and the request log on general, see the Monitoring and Maintaining documentation.

The Explain Query Tool

The Explain Query tool in ACS AEM Tools can be used to view the indexes that are used when running a query. This tool is useful when optimizing slow running queries.

PageSpeed Tools

Google’s PageSpeed tools offer site analysis for adherence to best practices for page performance and a plugin that can be installed alongside the Dispatcher on an Apache instance for additional optimizations.
See the PageSpeed Tools Website.