Troubleshooting
Problem
Resolving The Problem
Tab navigation
- Learning more- selected tab,
- Troubleshooting
- Collecting data
Collecting data for problems with the IBM® WebSphere® Application Server Liberty Profile classloader component. Gathering this MustGather information before calling IBM support will help you understand the problem and save time analyzing the data
This MustGather is needed to analyze exceptions such as: ClassNotFoundException, NoClassDefFoundError, ClassCastException, NoSuchMethodError, LinkageError, UnsatisfiedLinkError, VerifyError, UnsupportedClassVersionError, IncompatibleClassChangeError, ClassFormatError.
Collecting data manually
NOTE: Please see the following link for instructions to set classloader tracing on Websphere Traditional: MustGather: Classloader problems for WebSphere Application Server
Ensure that you complete all the steps as written, especially generating the server dump
- Open your server.xml file located within the <LIBERTY_HOME>/usr/servers/<server name>/ directory.
- Add the following <logging> element:
<logging traceSpecification="ClassLoadingService=all:SharedLibrary=all" traceFileName="trace.log" maxFileSize="100" maxFiles="10" traceFormat="BASIC"/> - If you do not have a jvm.options file within the <LIBERTY_HOME>/usr/servers/<server name>/ directory, create one.
- Add the following line to the first line of the jvm.options file:
-verbose:class - Backup and clear old log files within <LIBERTY_HOME>/usr/servers/<server name>/logs directory
- Stop the application server then start the server with the following parameter added
server start <SERVER_NAME> --clean
Note: For Liberty running in a containerized environment, the --clean option to start the server may be ineffective and can be omitted. If you are using Liberty Operator, then use the following day2-operations to enable the trace:
https://www.ibm.com/docs/en/was-liberty/base?topic=resources-webspherelibertytrace-custom-resource - Recreate the issue.
- Run the following command from the bin directory:
server dump <SERVER_NAME>
(this will create a compressed file .zip in the /usr/servers/<SERVER_NAME/ directory)
Note:Ensure the liberty server is running before using the server dump command. - Send the .zip file created from step 8 to IBM: Exchanging information with IBM support.
Additional Notes:
If you know the package you are experiencing issues with, you can enable classloading tracing for a specific package by changing the trace specification to:
com.ibm.ws.class.load.%packagename%.*=all
Example Usage:
com.ibm.ws.class.load.org.apache.cxf.*=all
If you are asked by IBM Support to enable OSGI trace, please follow the steps below:
- Append LogService=all to the classloader trace in step 2
- Create osgi.debug.options file with the following content:
- Add the following line to the jvm.options file:
Related information
Setting up trace and getting a full dump in the WebSphere Application Server V8.5 Liberty profile
Was this topic helpful?
Document Information
Modified date:
02 May 2024
UID
swg21972177