WebSphere eXtreme Scale Administration Guide > Configure WebSphere eXtreme Scale > Use WebSphere Real Time
WebSphere Real Time in WebSphere Application Server
You can use WebSphere Real Time with eXtreme Scale in a WAS ND environment version 7.0. By enabling WebSphere Real Time, you can get more predictable garbage collection along with a stable, consistent response time and throughput of transactions.
Advantages
Use WebSphere eXtreme Scale with WebSphere Real Time increases consistency and predictability at a cost of performance throughput in comparison to the default garbage collection policy employed in the standard IBM Java™ SE Runtime Environment (JRE). The cost versus benefit proposition can vary based on several criteria. The following are some of the major criteria:
- Server capabilities - Available memory, CPU speed and size, network speed and use
- Server loads – Sustained CPU load, peak CPU load
- Java configuration – Heap sizes, target use, garbage-collection threads
- WebSphere eXtreme Scale copy mode configuration – byte array vs. POJO storage
- Application specifics – Thread usage, response requirements and tolerance, object size, and so on.
In addition to this metronome garbage collection policy available in WebSphere Real Time, there are optional garbage collection policies available in standard IBM Java™ SE Runtime Environment (JRE). These policies, optthruput (default), gencon, optavgpause and subpool are specifically designed to solve differing application requirements and environments. For more information on these policies, see WebSphere eXtreme Scale JVM tuning. Depending upon application and environment requirements, resources and restrictions, prototyping one or more of these garbage collection policies can ensure that you meet your requirements and determine an optimal policy.
Capabilities with WebSphere Application Server Network Deployment
- The following are some supported versions.
- WAS ND version 7.0.0.5 and above.
- WebSphere Real Time V2 SR2 for Linux and above. See IBM WebSphere Real Time V2 for Linux for more information.
- WebSphere eXtreme Scale version 7.0.0.0 and above.
- Linux 32 and 64 bit operating systems.
- WebSphere eXtreme Scale servers cannot be collocated with a WebSphere Application Server DMgr.
- Real Time does not support DMgr.
- Real Time does not support WebSphere Node Agents.
Enable WebSphere Real Time
Install WebSphere Real Time and WebSphere eXtreme Scale onto the computers on which you plan to run eXtreme Scale. Update the WebSphere Real Time Java to SR2.
You can specify the JVM settings for each server through the WebSphere Application Server version 7.0 console as follows.
Choose Servers > Server types > WebSphere application servers > <required installed server>
On the resulting page, choose "Process definition."
On the next page, click Java Virtual Machine at the top of the column on the right. (Here you can set heap sizes, garbage collection and other flags for each server.)
Set the following flags in the "Generic JVM arguments" field:
-Xrealtime -Xgcpolicy:metronome -Xnocompressedrefs -Xgc:targetUtilization=80
Apply and save changes.
To use Real Time in WebSphere Application Server 7.0 to with eXtreme Scale servers including the JVM flags above, create a JAVA_HOME environment variable.
Set JAVA_HOME as follows.
- Expand "Environment".
- Select "WebSphere variables".
- Ensure that "All scopes" is checked under “Show scope".
- Select the required server from the drop-down list. (Do not select DMgr or node agent servers.)
- If the JAVA_HOME environment variable is not listed, select "New," and specify JAVA_HOME for the variable name. In the "Value" field, enter the fully qualified path name to Real Time.
- Apply and then save the changes.
Best practices
For a set of best practices see the best practices section in Use WebSphere Real Time. There are some important modifications to note in this list of best practices for a stand-alone WebSphere eXtreme Scale environment when deploying into a WebSphere Application Server Network Deployment environment.
You must place any additional JVM command line parameters in the same location as the garbage collection policy parameters specified in the previous section.
An acceptable initial target for sustained processor loads is 50% with short duration peek loads hitting up to 75%. Beyond this, add additional capacity before you see measurable degradation in predictability and consistency. You can increase performance slightly if you can tolerate longer response times. Exceeding an 80% threshold often leads to significant degradation in consistency and predictability.
Parent topic
Use WebSphere Real Time