Performance and memory issues in ThingWorx often appear at the Java Virtual Machine (JVM) level. We can frequently detect these issues by monitoring JVM garbage collection logs and thread dumps.
In this first of a multi-part series, let's discuss how to analyze JVM garbage collection (GC) logs to detect memory issues in our application.
What are GC logs? When enabled on the Apache server, the logs will show the memory usage over time and any memory allocation issues (See: How to enable GC logging in our KB for details on enabling this logging level). Garbage Collection logs capture all memory cleanup operations performed by the JVM. We can determine the proper memory configuration and whether we have memory issues by analyzing GC logs.
Where do I find the GC logs? When configured as per our KB article, GC logs will be written to your Apache logs folder. Check both the gc.out and the gc.restart files for issues if present, especially if the server was restarted when experiencing problems.
How do I read GC logs? There are a number of free tools for GC log analysis (e.g. http://gceasy.io, GCViewer). But GC logs can also be analyzed manually in a text editor for common issues.
Reading GC files:
Generally each memory cleanup operation is printed like this:
Additional information on specific GC operations you might see are available from Oracle.
A GC analysis tool will convert the text representation of the cleanups into a more easily readable graph:
Let's look at some common scenarios that might indicate a memory issue. A case should be opened with Technical Support if any of the following are observed:
Full GCs: Full GCs are undesirable as they are a ‘stop-the-world’ operation. The longer the JVM pause, the more impact end users will see:
Full GC Loop: Full GCs occurring in quick succession are referred to as a Full GC loop
16121.092: [Full GC: 7341688K->4367406K(8482304K), 38.774491 secs]
16160.11: [Full GC: 4399944K->4350426K(8482304K), 24.273553 secs]
16184.461: [Full GC: 4350427K->4350426K(8482304K), 23.465647 secs]
16207.996: [Full GC: 4350431K->4350427K(8482304K), 21.933158 secs]
Example – the red triangles occurring at the end of the graph are a visual indication that we're in a full GC loop:
Memory Leaks: Memory leaks occur in the application when an increasing number of objects are retained in memory and cannot be cleaned up, regardless of the type of garbage collection the JVM performs.
Example(memory is increasing steadily despite GCs until we'll eventually max out):
What should we do if we see these issues occurring?
good stuff Tudor!
Hii Tudor Costache,
Thanks for sharing the details. It is good.
I have set the java option values as mentioned in the GC log settings mentioned in the above links. (I am not running tomcat as a service)
set JAVA_OPTS="-Djava.awt.headless=true -Djava.net.preferIPv4Stack=true -Dserver -Dd64 -Xms512m -Xmx5g -XX:+UseNUMA -Xloggc:logs/gc.out -XX:+PrintGCTimeStamps -XX:+PrintGCDetails"
But i am not getting the gc.out created. I have also tried giving the exact path differently like Xloggc:D:\gc.out. Still no GC logs getting created.
I have also tried to execute a data table query which results when i give bigger number in max items say 1000000000. but that error is not coming in the gc file mentioned. that log file itslef is not getting created in the given location.
Please let me know if i am missing anything.
Details:
OS : Windows 10
Tomcat version : 8.0.38
JDK : 1.8.0_b92
Thingworx : 7.1.0
Has anybody else faced the problems similar to the above case?, If resolved, please post your comments here.
I am able to get the GC logs by using the same configurations in windows configurations manager mentioned in the GC settings link. Thanks.