Checking the results of CSQ4IVP1
The IVP is split into eight stages; each stage must complete with a zero completion code before the next stage is run. The IVP generates a report, listing:
- The name of queue manager that is being connected to.
- A one-line message showing the completion code and the reason code returned from each stage.
- A one-line informational message where appropriate.
A sample report is provided in Figure 5
For an explanation of the completion and reason codes, see the WebSphere MQ for z/OS Messages and Codes manual.
Some stages have more than one WebSphere MQ call and, in the event of failure, a message is issued indicating the specific WebSphere MQ call that returned the failure. Also, for some stages the IVP puts explanatory and diagnostic information into a comment field.
The IVP job requests exclusive control of certain queue manager objects and therefore should be single threaded through the system. However, there is no limit to the number of times the IVP can be run against your queue manager.
The functions performed by each stage are:
- Stage 1
- Connect to the queue manager by issuing MQCONN.
- Stage 2
- Determine the name of the system-command input queue used by the command server to retrieve request messages. This queue receives display requests from Stage 5.
To do this, the sequence of calls is:
- Issue an MQOPEN, specifying the queue manager name, to open the queue manager object.
- Issue an MQINQ to find out the name of the system-command input queue.
- Issue an MQINQ to find out about various queue manager event switches.
- Issue an MQCLOSE to close the queue manager object.
On successful completion of this stage, the name of the system-command input queue is displayed in the comment field.
- Stage 3
- Open an initiation queue using MQOPEN.
This queue is opened at this stage in anticipation of a trigger message, which arrives as a result of the command server replying to the request from Stage 5. The queue must be opened for input to meet the triggering criteria.
- Stage 4
- Create a permanent dynamic queue using the CSQ4IVP1.MODEL queue as a model. The dynamic queue has the same attributes as the model from which it was created. This means that when the replies from the command server request in Stage 5 are written to this queue, a trigger message is written to the initiation queue opened in Stage 3.
Upon successful completion of this stage, the name of the permanent dynamic queue is indicated in the comment field.
- Stage 5
- Issue an MQPUT1 request to the command server command queue.
A message of type MQMT_REQUEST is written to the system-command input queue requesting a display of process CSQ4IVP1. The message descriptor for the message specifies the permanent dynamic queue created in Stage 4 as the reply-to queue for the command server's response.
- Stage 6
- Issue an MQGET request from the initiation queue. At this stage, a GET WAIT with an interval of one minute is issued against the initiation queue opened in Stage 3. The message returned is expected to be the trigger message generated by the command server's response messages being written to the reply-to queue.
- Stage 7
- Delete the permanent dynamic queue created in Stage 4. As the queue still has messages on it, the MQCO_PURGE_DELETE option is used.
- Stage 8
- Open a dynamic queue.
- MQPUT a message with an expiry interval set.
- Wait for the message to expire.
- Attempt to MQGET the expired message.
- MQCLOSE the queue.
- Stage 9
- Open a dynamic queue.
- MQPUT a message.
- Issue MQCMIT to commit the current unit of work.
- MQGET the message.
- Issue MQBACK to backout the message.
- MQGET the same message and ensure the backout count is set to 1.
- Issue MQCLOSE to close the queue.
- Stage 10
- Disconnect from the queue manager using MQDISC.
After running the IVP, we can delete any objects that you no longer require.
If the IVP does not run successfully, try each step manually to find out which function is failing.
Figure 5. Sample report from CSQ4IVP1DATE : 2005.035 IBM WebSphere MQ for z/OS - V6 PAGE : 0001 INSTALLATION VERIFICATION PROGRAM PARAMETERS ACCEPTED. PROGRAM WILL CONNECT TO : CSQ1 ,OBJECT QUALIFER : CSQ4IVP1 INSTALLATION VERIFICATION BEGINS : STAGE 01 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR BRIDGE EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS EXCP FOR CHANNEL EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR SSL EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR INHIBITED EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR LOCAL EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR PERFORMENCE EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR REMOTE EVENTS STAGE 02 INFO: QMGR EVENT SWITCH IS OFF FOR START/STOP EVENTS STAGE 02 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 SYSTEM.COMMAND.INPUT STAGE 03 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 STAGE 04 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 CSQ4IVP1.BAB9810EFEAC8980 STAGE 05 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 STAGE 06 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 STAGE 07 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 STAGE 08 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 CSQ4IVP1.BAB9810F0070E645 STAGE 09 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 CSQ4IVP1.BAB9812BA8706803 STAGE 10 COMPLETE. COMPCODE : 0000 REASON CODE : 0000 >>>>>>>>>> END OF REPORT <<<<<<<<<<