Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mblauth/jdump
A tool for dumping JVM information (heap dumps, thread dumps, JFRs, NMT, mallinfo()) for multiple local JVMs in one go
https://github.com/mblauth/jdump
debugging heap-dump java jfr jvm openjdk profiling
Last synced: about 2 months ago
JSON representation
A tool for dumping JVM information (heap dumps, thread dumps, JFRs, NMT, mallinfo()) for multiple local JVMs in one go
- Host: GitHub
- URL: https://github.com/mblauth/jdump
- Owner: mblauth
- License: gpl-2.0
- Created: 2022-08-01T11:32:40.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-08-12T12:01:02.000Z (over 2 years ago)
- Last Synced: 2024-10-14T04:40:59.705Z (3 months ago)
- Topics: debugging, heap-dump, java, jfr, jvm, openjdk, profiling
- Language: Java
- Homepage:
- Size: 158 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# jdump
jdump is a tool that creates multiple forms of dumps for multiple OpenJDK HotSpot JVMs running on the local system in
one go. This might make it easier to request detailed JVM information for debugging issues on customer sites etc.
without needing to brief them on the details of using jcmd or similar tools.`java -jar jdump -A` for example will provide all supported types of dumps for all running JVMs that it manages to
connect to using the Attach API.## Supported jdump.dump types
Currently supported are
* Heap dumps
* Thread dumps (stack traces of all running threads)
* Java Flight Recordings## Usage
```
java -jar jdump.jar [-f] [-A] [-H] [-J] [-d] [-M] [-N] [-T]Options:
start without options to show UI, if not on a headless system
-f: name of the target folder (will be created if non-existent; current working directoy, if empty)
-A: produce all types of dumps for all JVMs running locally
-H: produce heap dumps for all JVMs running locally
-J: produce JFRs for all JVMs running locally
-M: produce mallinfo() stats on Linux with glibc
-d: the duration selected for the JFRs, in seconds, default: 5
-N: product Native Memory Tracks for all JVMs running locally
-T: produce thread dumps for all JVMs running locally```
## Development
To build and run the tool for testing, run ```./gradlew run --args=""``` with the desired tool
arguments.To build the tool into a jar file, run ```./gradlew jar```, the jar file will be generated in build/libs.
To build and run the tool into a standalone custom JVM, run ```./gradlew jlink```, the image will be generated in
image/. Copy it to your target system and execute image/bin/jdump to run the application.