Skip to main content

How to select GC for java application

Which garbage collection(GC) algorithm suite for the application


If you don't have any strict pause-time requirements, first run your application and allow the VM to select a collector.
If necessary, adjust the heap size to improve performance. If the performance still doesn't meet
your performance, then use the specific collector and try.
Performance is dependent on the size of the heap, the amount of live data maintained by the
application, and the number and speed of available processors.
If the recommended collector doesn't achieve the desired performance, then first attempt to
adjust the heap and generation sizes to meet the desired goals. If performance is still
inadequate, then try a different collector: Use the concurrent collector to reduce pause-time,
and use the parallel collector to increase overall throughput on multiprocessor hardware.

Available Collector in Oracle JDK

-XX:+UseSerialGC
-XX:+UseParallelGC
-XX:+UseG1GC
-XX:+UseConcMarkSweepGC
-XX:UseZGC 

How to enable GC logs

Turning on GC Logging in Java 7 / 8

java -XX:+PrintGCDetails -XX:+PrintGCDateStamps - Xloggc: <file-path>

Turning on GC Logging in Java 9 and Up

java –Xlog:gc*:file=<file-path>:filecount=10,filesize=10M

Dynamically Turning on GC Logging in Java 9 and Up

jcmd <pid> VM.log what=gc output=<file-path>

How to analyze GC logs

[0.010s][info][gc] Using G1
[0.028s][info][gc] Periodic GC disabled
[0.584s][info][gc] GC(0) Pause Young (Normal) (G1 Evacuation Pause) 23M->4M(130M) 3.386ms
[0.885s][info][gc] GC(1) Pause Young (Normal) (GCLocker Initiated GC) 38M->6M(130M) 3.475ms
[1.782s][info][gc] GC(2) Pause Young (Concurrent Start) (Metadata GC Threshold) 77M->8M(130M) 3.816ms
[1.782s][info][gc] GC(3) Concurrent Cycle
[1.789s][info][gc] GC(3) Pause Remark 9M->9M(40M) 2.746ms
[1.791s][info][gc] GC(3) Pause Cleanup 9M->9M(40M) 0.043ms
[1.792s][info][gc] GC(3) Concurrent Cycle 9.942ms
[2.141s][info][gc] GC(4) Pause Young (Normal) (G1 Evacuation Pause) 27M->10M(40M) 5.106ms
[2.404s][info][gc] GC(5) Pause Young (Normal) (G1 Evacuation Pause) 29M->11M(40M) 2.537ms
[2.628s][info][gc] GC(6) Pause Young (Normal) (G1 Evacuation Pause) 29M->12M(40M) 3.846ms

This is an example of a CG log file , reading and analyzing this text file is a tedious task. There are some tools available for log analysis.

Comments

Popular posts from this blog

About virtual thread in java

In this blog post, I will introduce you to the concept of virtual threads in Java and how they can improve the performance and scalability of your applications that rely on networking I/O. Virtual threads are lightweight threads that reduce the effort of writing, maintaining, and debugging high-throughput concurrent applications. They are instances of java.lang.Thread that are not tied to a specific operating system (OS) thread, but rather run on a small number of OS threads managed by the Java runtime. This allows the Java runtime to suspend and resume virtual threads when they perform blocking I/O operations, freeing up the OS threads for other tasks. Virtual threads typically have a shallow call stack and perform as few as a single HTTP client call or a single JDBC query. They are suitable for tasks that spend most of their time waiting for I/O, but not for long-running CPU-intensive tasks. Virtual threads are supported by the Java Platform since Java SE 21. They are part of Project...

Angular 2 Typescript without node or npm

To getting start with angular2 app, we need to setup some bunch of  tool and boilerplate codes. Fortunately there are many easy getting-start projects available for angular2. Those are  angular-cli , angual2-seed etc. Anyway we need to rely on node and npm, that would need for real angular2 projects. But sometimes we need to test  angular2 features  and share demo codes with others. Installing large node modules and setting-up not worth for this kind of task. However for small task you can use angular2 without npm.     have a look at github repository -  https://github.com/ishara/angular2-without-npm happy coding.

is not a JMX compliant Standard MBean

I got the fallowing exception and issue solved. If your are using MBean , MBean Interface and Implementation should be in same package, Otherwise use MXBean. javax.management.NotCompliantMBeanException: MBean class comlanka.rest.controller.DataManagerController does not implement DynamicMBean, and neither follows the Standard MBean conventions (javax.management.NotCompliantMBeanException: Class comlanka.rest.controller.DataManagerController is not a JMX compliant Standard MBean) nor the MXBean conventions (javax.management.NotCompliantMBeanException: comlanka.rest.controller.DataManagerController: Class comlanka.rest.controller.DataManagerController is not a JMX compliant MXBean)         at com.sun.jmx.mbeanserver.Introspector.checkCompliance(Introspector.java:176)         at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:317)         at com.sun.jmx.mbeanserver.Jmx...