The tool analyzes Javacores and verbose gc logs and provides some reports like cpu/gc usage, blocked threads, some tips regarding the javacores. The tool can process the following data:
- Set of Javacores from the same run. Optionally you can add verbose.gc log file
- Single Javacore
The tool requires Python 3.9 or higher plus some packages - see more in REQUIREMENTS. Despite it is not mandatory, it is recommended in Python to use virtual environment to manage packages.
This is most common option which you will need in 99% of situations
Steps:
- Download and install Python. Usually the latest version is supported. Search for supported versions in REQUIREMENTS
- Create and activate Virtual Environment according to Creating virtual environments.
- Run the following command:
pip install javacore-analyser
 ORpip install --pre javacore-analyser- if you want an experimental version
This is recommended for geeks only:
- Repeat steps 1 and 2 from above
- Download the project files either from Releases or from main
- Extract the code and from code directory execute
pip install .
- Install application if not done yet
- Activate your created virtual environment according to activate Virtual Environment according to Creating virtual environments
- Run the following command from cmd:
 javacore-analyser-batch <input-data> <generated-reports-dir>
 or
 python -m javacore_analyser batch <input-data> <generated-reports-dir>
Where <input-data> is one of the following:
- The directory containing javacores and optionally verbose gc
- Archive (7z, zip, tar.gz, tar.bz2) containing the same
- List of the javacores separated by ;character. Optionally you can add--separatoroption to define your own separator.
- You can specify --skip_boring=Falseif you want drill-down pages generated for all the threads, including the ones that do not do anything interesting. You can type the following command to obtain the help:
 javacore-analyser-batch --helporpython -m javacore_analyser batch --help
- 
Repeat steps 1-3 from cmd application 
- 
Execute the following command from cmd: 
 javacore_analyser_web --port=5000 --reports-dir=/data/reports_dir
 or
 python -m javacore_analyser web --port=5000 --reports-dir=/data/reports_dirThe first parameter set the port to use by application. If not specified, 5000 will be used. 
 The second parameter sets where the reports need to be stored. If not set, then thereportsdir will be created in current location.
Now you can type (http://localhost:5000/).
There is a Docker/Podman container managed by one of projects developers. Use the following command to start it:
podman run -it --rm --name javacore-analyser --mount type=bind,src="/local-reports-dir",target=/reports -p 5001:5000 ghcr.io/ibm/javacore-analyser:latest
or
docker run -it --rm --name javacore-analyser --mount type=bind,src="/local-reports-dir",target=/reports -p 5001:5000 ghcr.io/ibm/javacore-analyser:latest
The mount option specifies where you want locally to store the reports. The reports in the container are stored in
/reports directory. If you remove mount option, the application will work but the reports will not persist after
restart.
The application is running in the container on port 5000. By using -p 5001:5000 option, you specify to map container
port 5000 to port 5001 on your machine. Therefore the application will be available under http://localhost:5001/.
NOTE: If you get a PermissionError: [Errno 13] Permission denied: '/reports/wait2-debug.log' message,
try specifying a different folder as the src parameter value or use the
--volume option instead of --mount. Find more on
Issue #140.
There is a collector available that will gather javacores, verbose gc and some further server configuration (ulimit, ps, memory and disk usage) for Linux systems.
Perform the following steps to run the tool:
- Download the collector from javacoreCollector.sh to the machine where you want to gather data.
- Execute it with the following command:
./javacoreCollector.sh libertyPath=/opt/ibm/liberty server=liberty_server_name - for collecting diagnostic data from a java application running on an IBM WebSphere Liberty profile,
or
./javacoreCollector.sh javaPid=12345 javacoresDir=/location/for/javacores - for collecting diagnostic data from any java aplication.
You can add the 'count' and 'interval' parameters to specify the number of javacores (default: 10) and interval between each of them (defaul: 30s).
Type ./javacoreCollector.sh to get more help.
After collection, the collector creates javacores.tar.gz file containing the following data:
- javacore files,
- Verbose gc files, if found in javacoresDirorlibertyPathlocation,
- Ulimit settings in ulimit.txtfile,
- output from ps, memory and disk usage it iteration files. This data is gathered periodically with the same interval as javacores. There is separate file created for each collection.
If you have any questions or issues you can create a new issue here.
Pull requests are very welcome! Make sure your patches are well tested. Ideally create a topic branch for every separate change you make. For example:
- Fork the repo
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Added some feature')
- Push to the branch (git push origin my-new-feature)
- Create new Pull Request
All source files must include a Copyright and License header. The SPDX license header is preferred because it can be easily scanned.
If you would like to see the detailed LICENSE click here.
#
# Copyright IBM Corp. {Year project was created} - {Current Year}
# SPDX-License-Identifier: Apache-2.0
#
- Krzysztof Kazmierczyk kazm@ibm.com
- Piotr Aniola Piotr.Aniola@ibm.com
- Tadeusz Janasiewicz t.janasiewicz@ibm.com
Another useful pages: