IBM MQ for z/OS performance constraints
Use this topic to investigate z/OS resources that can cause performance constraints.
There are a number of decisions to be made when customizing IBM MQ for z/OS that can affect the way the systems perform. These decisions include:- The size and placement of data sets
- The allocation of buffers
- The distribution of queues among page sets, and Coupling Facility structures
- The number of tasks that you allow to access the queue manager at any one time
Log buffer pools
Insufficient log buffers can cause applications to wait until a log buffer is available, which can affect IBM MQ performance. RMF reports might show heavy I/O to volumes that hold log data sets.
There are three parameters we can use to tune log buffers. The most important is OUTBUFF. If the log manager statistic QJSTWTB is greater than 0, increase the size of the log buffer. This parameter controls the number of buffers to be filled before they are written to the active log data sets (in the range 1 - 256). Commits and out-of-syncpoint processing of persistent messages cause log buffers to be written out to the log. As a result this parameter might have little effect except when processing large messages, and the number of commits or out of sync point messages is low. These parameters are specified in the CSQ6LOGP macro (see Use CSQ6LOGP for details), and the significant ones are:
- OUTBUFF
- This parameter controls the size of the output buffer (in the range 40 KB through 4000 KB).
- WRTHRSH
- This parameter controls the number of buffers to be filled before they are written to the active log data sets (in the range 1 through 256).
We must also be aware of the LOGLOAD parameter of the CSQ6SYSP macro. This parameter specifies the number of log records that are written between checkpoint records. The range is 200 through 16 000 000 but a typical value for a large system is 500 000. If a value is too small you receive frequent checkpoints, which consume processor time and can cause additional disk I/O.
Buffer pool size
There is a buffer pool associated with each page set. We can specify the number of buffers in the buffer pool using the DEFINE BUFFPOOL command.
Incorrect specification of buffer pool size can adversely affect IBM MQ performance. The smaller the buffer pool, the more frequently physical I/O is required. RMF might show heavy I/O to volumes that hold page sets. For buffer pools with only short-lived messages the buffer manager statistics QPSTSLA, QPSTSOS, and QPSTRIO must typically be zero. For other buffer pools, QPSTSOS and QPSTSTLA must be zero.
Distribution of data sets on available DASD
The distribution of page data sets on DASD can have a significant effect on the performance of IBM MQ.
Place log data sets on low usage volumes with log n and log n+1 on different volumes. Ensure that dual logs are placed on DASD on different control units and that the volumes are not on the same physical disk.
Distribution of queues on page sets
The distribution of queues on page sets can affect performance. This change in performance can be indicated by poor response times experienced by transactions using specific queues that reside on heavily used page sets. RMF reports might show heavy I/O to volumes containing the affected page sets.
We can assign queues to specific page sets by defining storage class (STGCLASS) objects specifying a particular page set, and then defining the STGCLASS parameter in the queue definition. It is a good idea to define heavily used queues on different page sets in this way.
Distribution of queues on Coupling Facility structures
The distribution of queues on Coupling Facility structures can affect performance.
A queue sharing group can connect to up to 64 Coupling Facility structures, one of which must be the administration structure. We can use the remaining 63 Coupling Facility structures for IBM MQ data with each structure holding up to 512 queues. If you need more than one Coupling Facility structure, separate the queues across several structures based on the function of the queue.
There are some steps we can take to maximize efficiency:- Delete any Coupling Facility structures you no longer require.
- Place all the queues used by an application on the same Coupling Facility to make application processing efficient.
- If work is particularly performance sensitive, choose a faster Coupling Facility structure.
Consider that if you lose a Coupling Facility structure, you lose any non-persistent messages stored in it. The loss of these non-persistent messages can cause consistency problems if queues are spread across various Coupling Facility structures. To use persistent messages, we must define the Coupling Facility structures with at least CFLEVEL(3) and RECOVER(YES).
Limitation of concurrent threads
The number of tasks accessing the queue manager can also affect performance, particularly if there are other constraints, such as storage, or there are many tasks accessing a few queues. The symptoms can be heavy I/O against one or more page sets, or poor response times from tasks known to access the same queues. The number of threads in IBM MQ is limited to 32767 for both TSO and Batch.
In a CICS environment, we can use CICS MAXTASK to limit concurrent access.
Use the IBM MQ trace for administration
Although you might have to use specific traces on occasion, using the trace facility has a negative effect on the performance of our systems.
Consider what destination we want your trace information sent to. Using the internal trace table saves I/O, but it is not large enough for traces that produce large volumes of data.
The statistics trace gathers information at intervals. The intervals are controlled by the STATIME parameter of the CSQ6SYSP macro, described in Use CSQ6SYSP. An accounting trace record is produced when the task or channel ends, which might be after many days.
We can limit traces by class, resource manager identifier (RMID), and instrumentation facility identifier (IFCID) to reduce the volume of data collected. See START TRACE for more information.
Parent topic: Problem determination on z/OS