Java cache for user classloaders

The OS/400 JVM user classloader cache is a feature that allows the JVM to "remember" classes that have been loaded with user classloaders. This feature improves the startup performance of classes loaded by user class loaders by allowing the JVAPGMs created by user classloaders to be cached for reuse, avoiding JVAPGM creation and bytecode verification during the initial class load. WebSphere components (servlets, JSPs and enterprise beans) are loaded by user classloaders and can take advantage of this feature.

For most applications, the default WebSphere setup provides the best solution. You should only consider the techniques described here if you are experiencing performance problems in the following areas:

The user classloader cache improves performance in two ways:

Note in both cases the first time the class is loaded (for example before the cache is primed or after a class is changed), these functions will be performed and the load will be slower. Once the class is already in the cache, these functions will not be performed, so subsequent loads will be much quicker. There is no way to prime the cache with classes other than running your application.

Use the User Classloader Cache

To enable the user classloader cache, the Java system property os400.define.class.cache.file must be specified with a valid value. Other Java system properties may be optionally specified. Use the following Java system properties to enable and customize the user classloader cache:

Note that other Java system properties, such as os400.defineClass.optLevel, can be used to customize how JVAPGMs are created in the cache.

To add Java system properties to an application server, perform these steps:

  1. In the administrative console select Servers and then Application Servers.
  2. Click on the application server you want to modify.
  3. In the Additional properties section, click Process Definition.
  4. In the Additional properties section, click Java Virtual machine.
  5. In the Additional properties section, click Custom Properties.
  6. Click New to add a property.

For example, to use the shipped cache JAR with a maximum of 10,000 JVAPGMs that have a maximum life of 1 year, you would add the following:

PropertyValue
os400.define.class.cache.file/QIBM/ProdData/Java400/QDefineClassCache.jar
os400.define.class.cache.hours8760
os400.define.class.cache.maxpgms10000