CPU Profiling
Pre-requisites
- Install Java - JDK 11
- Install sfAgent on Linux
note
- Add profile key and SnappyFlow tags in the config.yaml.
- For existing customers, update SFAgent config.yaml with latest - profile key, if SFAgent is already deployed.
- Reference for installing sfAgent : Click here
- Name and AppName should always be unique (pair).
- jcmd equivalent : Application Dashboard >> Process Name
CPU Profiling
- CPU profiling provides the thread wise CPU usage.
- Profiling helps us to identify various issues :
- Synchronization Issues :
- Deadlock Situation : when several threads running hold a synchronized block on a shared object
- Thread Contention : when a thread is blocked waiting for others to finish
- Execution Issues :
- Abnormally high CPU usage : when a thread is in running state for a very long period of time
- Processing Performance is low : when many threads are blocked
- Synchronization Issues :
- It also provides an ability to correlate the thread stack at that time.
- Java CPU profiling can be collected by using Java profiling plugin.
config.yaml
metrics:
plugins:
- name: javaprofiling
enabled: true
interval: 10
target: profile
config:
process: process_name # otherwise mention '*'
monitorCpuProfiling: true
cpuProfilingInterval: 10
stackTraceLimit: 25
CPU profiling interval :
- It is by default set to 10 seconds.
- It is recommended to keep it 10s to get better overview to the thread.
- Increasing this we might miss out frequent thread state changes.
Stack trace limit :
- It is set to 25 by default.
- If need this can be increased or decreased.
CPU Profiling tool :
- It itself will consume some amount of CPU.
- The feature can be turned off after fixing your issue using the flag monitorCpuProfiling.
Process :
- It provides the process name for which CPU profiling needs to be enabled. Regex can also be used.
CPU Profiling Dashboards :
To view the CPU profiling dashboards :
- Dashboards >> Profiling pane >> Select Java in the language dropdown next
- CPU Profiling from the dropdown >> Select the instance, process name from the next dropdowns.
- It displays the thread activity in the form of visuals.
- We can easily find blocked threads and reasons why they are blocked.
Screenshots
Click on the filter icon to add filters.
data:image/s3,"s3://crabby-images/7d492/7d492f93d2324d2d28888df9a186ed935f34493d" alt=""
To add filters, write the thread name by prepending ~
in the Filter column : e.g. ThreadName ~ Thread-8
and then click on OK.
data:image/s3,"s3://crabby-images/dd344/dd344b0eb00b0dbc4b1b22a82787afe22f32138b" alt=""
Click the thread from the list.
data:image/s3,"s3://crabby-images/bcb39/bcb3927f903d1ad1d54f724799fa53a06207664e" alt=""
data:image/s3,"s3://crabby-images/f1126/f1126886d0aeb17f5ffc267d0bfc79ee798f0e3d" alt=""
You can modify the start and end time of the thread in the Stats Breakup.
data:image/s3,"s3://crabby-images/f66d5/f66d587ed8a12330fca251ed825cd628d2207393" alt=""
You can expand the list item to get more information.
data:image/s3,"s3://crabby-images/d2639/d2639ee3d86b3ee95c9b8ba625bf76de1755ca36" alt=""
Hover over the graphs to get quick summary about Thread States and CPU Util by Thread.
data:image/s3,"s3://crabby-images/a3ce9/a3ce9756538c04543b8da7ef6b71d69ed58f52f3" alt=""
data:image/s3,"s3://crabby-images/88c19/88c19d2cbbf8cc8824a9e9a5757677af806a1e66" alt=""
data:image/s3,"s3://crabby-images/0fc0b/0fc0b4a3168cff257577a68b33baa92778feb1f3" alt=""