Troubleshooting z/OS Services
The following topics contain information that can help you troubleshoot problems when you encounter unexpected behavior installing and using Zowe™ z/OS Services.
#
z/OSMF JVM cache corruptionSymptom:
When you work with Zowe, there are situations when z/OSMF abends.
The following is a snippet from the Java core dump.
Solution:
The error occurs when the Java runtime being used by the z/OSMF Liberty server and the Java runtimes being used by Zowe share a user ID of IZUSVR1
, which results in a collision. To resolve this issue, review the following steps.
#
Isolate the started task user IDsThe z/OSMF started task IZUSVR1
runs under the user ID of IZUUSER
. Before version 1.9 of Zowe, its started task ZWESVSTC
also ran under the same user ID. With Zowe 1.9, the default configuration changed to use a new user ID of ZWESVUSR
and group of ZWEADMIN
.
If your started task ZWESVSTC
is configured to run under the user ID IZUUSER
, change it to run under user ID ZWESVUSR
. For more information, see Configuring the z/OS System for Zowe.
#
Update z/OSMF to not use JVM class cachingIf you need to run ZWESVSTC
under the same user ID as z/OSMF for your environment, you can update the z/OSMF configuration to switch off shared class caching which stops the crash from occurring. Disabling shared class caching reduces the performance of z/OSMF so the preferred fix is to change the user ID of ZWESVSTC
away from IZUUSER
to ZWESVUSR
as described above.
Navigate to the file /var/zosmf/configuration/local_override.cfg
. This contains the startup arguments for the Java runtime used by z/OSMF. Add the following line:
You will need to recycle the z/OSMF server running, which by default will be running under the started task IZUSVR1
.
For more information on the effect that disabling a shared class cache has on a Java runtime, see Class data sharing in the IBM Knowledge Center.
#
Unable to generate unique CeaTso APPTAGSymptom:
When you request a Zowe data set or z/OS Files API, you receive a response code 500 - 'Internal Server Error', with a message "Unable to generate unique CeaTso APPTAG".
Solution:
Check z/OSMF settings of REST API of file. You must define RESTAPI_FILE
in IZUPRMxx by the following statement:
RESTAPI_FILE ACCT(IZUACCT) REGION(32768) PROC(IZUFPROC)
The default IZUFPROC can be found in SYS1.PPROCLIB. And the proper authorization is needed to get IZUFPROC work successfully.
#
z/OS Services are unavailableIf the z/OS Services are unavailable, take the following corrective actions.
Ensure that the z/OSMF REST API services are working. Check the z/OSMF IZUSVR1 task output for errors and confirm that the z/OSMF RESTFILES services are started successfully. If no errors occur, you can see the following message in the IZUSVR1 job output:
To test z/OSMF REST APIs you can run curl scripts from your workstation.
where the securezosmfport is 443 by default. You can verify the port number by checking the izu.https.port variable assignment in the z/OSMF
bootstrap.properties
file.If z/OSMF returns jobs correctly, you can test whether it is able to returns files by using the following curl scripts:
If the restfiles curl statement returns a TSO SERVLET EXCEPTION error, check that the the z/OSMF installation step of creating a valid IZUFPROC procedure in your system PROCLIB has been completed. For more information, see the z/OSMF Configuration Guide.
The IZUFPROC member resides in your system PROCLIB, which is similar to the following sample:
Note: You might need to change paths and data sets names to match your installation.
A known issue and workaround for RESTFILES API can be found at TSO SERVLET EXCEPTION ATTEMPTING TO USE RESTFILE INTERFACE.
Check your system console log for related error messages and respond to them.