Request body attributes for queues
When you create the request body for creating or modifying a queue with
the administrative REST API, we can specify attributes for the queue within named JSON objects. A
number of objects and attributes are available.
The following objects are available:
For more information about the PCF equivalents to the queue REST API parameters and attributes,
see REST API and PCF equivalents
for queues.
remote
Note: The remote object and the qmgrName attribute are required
when you create a remote queue by using the HTTP POST method. We cannot use the
remote object unless you are creating a remote queue, or updating a remote
queue.
The remote object can contain the following attributes that relate to remote
queues:
- queueName
- String.
- Specifies the name of the queue as it is known on the remote queue manager.
- If this attribute is omitted, a queue manager alias or reply-to queue alias is created.
- qmgrName
- String.
- Specifies the name of the remote queue manager.
- Required when you create a queue by using the HTTP POST method, unless we use the
like optional query parameter.
- If this remote queue is used as a queue manager alias, this attribute is the name of the queue
manager. The value can be the name of the queue manager in the resource URL.
- If this remote queue is used as a reply-to queue alias, this attribute is the name of the queue
manager that is to be the reply-to queue manager.
- transmissionQueueName
- String.
- Specifies the name of the transmission queue that is to be used for messages that are destined
for either a remote queue or for a queue manager alias definition.
- This attribute is ignored in the following cases:
- The remote queue is used as a queue manager alias and qmgrName attribute is
the name of the queue manager in the resource URL.
- The remote queue is used as a reply-to queue alias.
- If this attribute is omitted, a local queue with the name that is specified by the
qmgrName attribute must exist. This queue is used as the transmission
queue.
alias
Note: The alias object and the targetName attribute are required
when you create an alias queue by using the HTTP POST method. We cannot use the
alias object unless you are creating an alias queue, or updating an alias
queue.
The alias object can contain the following attributes that relate to alias
queues:
- targetName
- String.
- Specifies the name of the queue or topic that the alias resolves to.
- Required when you create a queue by using the HTTP POST method, unless we use the
like optional query parameter.
- targetType
- String.
- Specifies the type of object that the alias resolves to.
- The value must be one of the following values:
- queue
- Specifies that the object is a queue.
- topic
- Specifies that the object is a topic.
- The default value is queue.
model
Note: The model object and the type attribute are required when
you create a model queue by using the HTTP POST method. We cannot use the model
object unless you are creating a model queue, or updating a model queue.
The model object can contain the following attributes that relate to model
queues:
- type
- String.
- Specifies the model queue definition type.
- The value must be one of the following values:
- permanentDynamic
- Specifies that the queue is a dynamically defined permanent queue.
- sharedDynamic
- This attribute is only available on z/OSĀ®.
- Specifies that the queue is a dynamically defined shared queue.
- temporaryDynamic
- Specifies that the queue is a dynamically defined temporary queue.
- The default value is temporaryDynamic.
cluster
The cluster object can contain the following attributes that relate to
clusters:
- name
- String.
- Specifies the name of the cluster that the queue belongs to.
- Specify either the name or namelist cluster
attributes. We cannot specify both attributes.
- namelist
- String.
- Specifies the namelist that lists the clusters that the queue belongs to.
- Specify either the name or namelist cluster
attributes. We cannot specify both attributes.
- transmissionQueueForChannelName
- String.
- Specifies the generic name of the cluster-sender channels that use the queue as a transmission
queue. The attribute specifies which cluster-sender channels send messages to a cluster-receiver
channel from the cluster transmission queue.
- We can also set this attribute to a cluster-sender channel manually. Messages that are destined
for the queue manager that is connected by the cluster-sender channel are stored in the transmission
queue that identifies the cluster-sender channel. The messages are not stored in the default cluster
transmission queue.
- If you set the transmissionQueueForChannelName attribute to blanks, the
channel switches to the default cluster transmission queue when the channel restarts. The default
cluster transmission queue is SYSTEM.CLUSTER.TRANSMIT.QUEUE if the queue manager
DefClusterXmitQueueType attribute is set to SCTQ. A specific
cluster transmission queue, SYSTEM.CLUSTER.TRANSMIT.ChannelName,
is used for each cluster-sender channel if the queue manager
DefClusterXmitQueueType attribute is set to CHANNEL.
- By specifying asterisks, *, in transmissionQueueForChannelName, we can
associate a transmission queue with a set of cluster-send channels. The asterisks can be at the
beginning, end, or any number of places in the middle of the channel name string.
- workloadPriority
- Integer.
- Specifies the priority of the queue in cluster workload management.
- The value must be in the range 0 - 9, where 0 is the lowest priority and 9 is the highest.
- workloadRank
- Integer.
- Specifies the rank of the queue in cluster workload management.
- The value must be in the range 0 - 9, where 0 is the lowest priority and 9 is the highest.
- workloadQueueUse
- String.
- Specifies whether remote and local instances of the clustered queues are to be used in cluster
workload distribution.
- The value must be one of the following values:
- asQmgr
- Use the value that is defined on the queue manager.
- any
- Use remote and local instances of the queues.
- local
- Use only local instances of the queues.
trigger
The trigger object can contain the following attributes that relate to
triggering:
- data
- String.
- Specifies the user data that is included in the trigger message. This data is made available to
the monitoring application that processes the initiation queue and to the application that is
started by the monitor.
- depth
- Integer.
- Specifies the number of messages that initiates a trigger message to the initiation queue.
- The value must be in the range 1 - 999,999,999.
- This attribute is required when type is set to depth.
- enabled
- Boolean.
- Specifies whether trigger messages are written to the initiation queue.
- If the value is set to true, trigger messages are written to the initiation
queue.
- initiationQueueName
- String.
- Specifies the local queue for trigger messages that relate to the queue. The queues must be on
the same queue manager.
- messagePriority
- Integer.
- Specifies the minimum priority that a message must have before it can cause, or be counted for,
a trigger event.
- The value must be in the range 0 - 9.
- processName
- String.
- Specifies the local name of the IBM MQ process that
identifies the application to be started when a trigger event occurs.
- If the queue is a transmission queue, the process definition contains the name of the channel to
be started.
- type
- String.
- Specifies the condition that initiates a trigger event. When the condition is true, a trigger
message is sent to the initiation queue.
- The value must be one of the following values:
- none
- Send no trigger messages.
- every
- Send a trigger message for every message that arrives on the queue.
- first
- Send a trigger message when the queue depth goes from 0 to 1.
- depth
- Send a trigger message when the queue depth exceeds the value of the
depthattribute.
events
The events object can contain the following objects and attributes that relate
to queue depth and queue service interval events:
- depth
- JSON object.
- A JSON object that can contain the following attributes that related to queue depth events:
- fullEnabled
- Boolean.
- Specifies whether queue full events are generated.
- A queue full event indicates that no more messages can be put on a queue because the queue is
full. That is, the queue depth reached the maximum queue depth, as specified by the
maximumDepth attribute in the storage object.
- If the value is set to true, queue full events are enabled.
- highEnabled
- Boolean.
- Specifies whether queue depth high events are generated.
- A queue depth high event indicates that the number of messages on the queue is greater than or
equal to the queue depth high limit, highPercentage.
- If the value is set to true, queue depth high events are enabled.
- highPercentage
- Integer.
- Specifies the threshold against which the queue depth is compared to generate a queue depth high
event.
- This value is expressed as a percentage of the maximum queue depth, as specified by the
maximumDepth attribute in the storage object. The value must
be a value in the range 0 - 100.
- lowEnabled
- Boolean.
- Specifies whether queue depth low events are generated.
- A queue depth low event indicates that the number of messages on the queue is less than or equal
to the queue depth low limit, lowPercentage.
- If the value is set to true, queue depth low events are enabled.
- lowPercentage
- Integer.
- Specifies the threshold against which the queue depth is compared to generate a queue depth low
event.
- This value is expressed as a percentage of the maximum queue depth, as specified by the
maximumDepth attribute in the storage object. The value must
be a value in the range 0 - 100.
- serviceInterval
- JSON object.
- A JSON object that can contain the following attributes that are related to queue service
interval events:
- duration
- Integer.
- Specifies the service interval duration that is used for comparison to generate queue service
interval high and queue service interval OK events.
- The value must be a value in the range 0 - 999,999,999 milliseconds.
- highEnabled
- Boolean.
- Specifies whether queue service interval high events are generated.
- A queue service interval high event is generated when a check indicates that no messages were
put to, or retrieved from, the queue for at least the amount of time specified by the
duration attribute.
- If the value is set to true, queue service interval high events are
enabled.
- If you set the highEnabled attribute to false, you must
also specify a value for the okEnabled attribute. We cannot set both the
highEnabled attribute and the okEnabled attribute to true
at the same time.
- okEnabled
- Boolean.
- Specifies whether queue service interval OK events are generated.
- A queue service interval OK event is generated when a check indicates that a message was
retrieved from the queue within the amount of time that is specified by the
duration attribute.
- If the value is set to true, queue service interval OK events are enabled.
- If you set the okEnabled attribute to false, you must also
specify a value for highEnabled. We cannot set both the
highEnabled attribute and the okEnabled attribute to
true at the same time.
applicationDefaults
The applicationDefaults object can contain the following attributes that relate
to default behavior such as message persistence:
- clusterBind
- String.
- Specifies the binding to be used when MQOO_BIND_AS_Q_DEF is specified on the
MQOPEN call.
- The value must be one of the following values:
- onOpen
- Specifies that the binding is fixed by the MQOPEN call.
- notFixed
- Specifies that the binding is not fixed.
- onGroup
- Specifies that the application can request that a group of messages is allocated to the same
destination instance.
- messagePersistence
- String.
- Specifies the default for message persistence on the queue. Message persistence determines
whether messages are preserved across restarts of the queue manager.
- The value must be one of the following values:
- persistent
- Specifies that the messages on the queue are persistent, and are preserved when the queue
manager restarts.
- nonPersistent
- Specifies that the messages on the queue are not persistent, and are lost when the queue manager
restarts.
- messagePriority
- Integer.
- Specifies the default priority of messages that are put on the queue.
- The value must be in the range 0 - 9, where 0 represents the lowest priority, and 9 represents
the highest priority.
- messagePropertyControl
- String.
- Specifies how message properties are handled when messages are retrieved from queues when
MQGMO_PROPERTIES_AS_Q_DEF is specified on the MQGET call.
- This attribute is applicable to local, alias, and model queues.
- The value must be one of the following values:
- all
- Specifies that all properties of the message are included when the message is sent to the remote
queue manager. The properties, except those properties in the message descriptor or extension, are
place in one of more MQRFH2 headers in the message data.
- compatible
- Specifies that if the message contains a property with the prefix mcd.,
jms., usr., or mqext., all message properties are
delivered to the application in an MQRFH2 header. Otherwise, all properties, except
those properties in the message descriptor or extension, are discarded and are no longer
accessible.
- force
- Specifies that properties are always returned in the message data in an MQRFH2
header regardless of whether the application specifies a message handle. A valid message handle that
is included in the MsgHandle field of the MQGMO structure on the MQGET call is ignored. Properties
of the message are not accessible by using the message handle.
- none
- Specifies that all properties of the message are removed from the message before the message is
sent to the remote queue manager. Properties in the message descriptor, or extension, are not
removed.
- version6Compatible
- Any application MQRFH2 header is received as it was sent. Any properties set by
using MQSETMP must be retrieved by using MQINQMP. They are not added to the MQRFH2
created by the application. Properties that were set in the MQRFH2 header by the
sending application cannot be retrieved by using MQINQMP.
- putResponse
- String.
- Specifies the type of response that is to be used for put operations to the queue when an
application specifies MQPMO_RESPONSE_AS_Q_DEF.
- The value must be one of the following values:
- synchronous
- The put operation is run synchronously, returning a response.
- asynchronous
- The put operation is run asynchronously, returning a subset of MQMD fields.
- readAhead
- String.
- Specifies the default read-ahead behavior for non-persistent messages that are delivered to the
client.
- The value must be one of the following values:
- no
- Specifies that non-persistent messages are not read ahead unless the client application is
configured to request read ahead.
- yes
- Specifies that non-persistent messages are sent ahead to the client before an application
requests them. Non-persistent messages can be lost if the client ends abnormally or if the client
does not consume all the messages that it is sent.
- disabled
- Specifies that non-persistent messages are not read ahead, regardless of whether read ahead is
requested by the client application.
- sharedInput
- Boolean.
- Specifies the default share option for applications that open this queue for input.
- If the value is set to true, queues are enabled to get messages with shared
access.
queueSharingGroup
The queueSharingGroup object can contain the following attributes
that relate to queue sharing groups:
- disposition
- String.
- This attribute is only available on z/OS.
- Specifies where the queue is defined and how it behaves. That is, it specifies the disposition
of the queue.
- The value must be one of the following values:
- copy
- Specifies that the queue definition exists on the page set of the queue manager that runs the
command. The group object of the same name as the name attribute is used to
create the queue.
- For local queues, messages are stored on the page sets of each queue manager and are available
only through that queue manager.
- group
- Specifies that the queue definition exists in the shared repository.
- This value is allowed only in a shared queue manager environment.
- If the creation is successful, the following MQSC command is generated and sent to all active
queue managers in the queue sharing group. The command attempts to make or refresh local copies on
page set zero:
DEFINE queue(q-name) REPLACE QSGDISP(COPY)
The creation of the
group object takes effect even if the generated command with QSGDISP(COPY) fails.
- qmgr
- Specifies that the queue definition exists on the page set of the queue manager that runs the
command.
- For local queues, messages are stored on the page sets of each queue manager and are available
only through that queue manager.
- shared
- This value is only valid for local queues.
- Specifies that the queue exists in the shared repository.
- Messages are stored in the coupling facility and are available to any queue manager in the
queue sharing group. We can specify shared only if the following things are true:
- The value of structureName is not blank.
- The value of indexType is not messageToken.
- The queue is not SYSTEM.CHANNEL.INITQ or
SYSTEM.COMMAND.INPUT.
- The default value is qmgr.
- structureName
- String.
- This attribute is only available on z/OS.
- Specifies the name of the coupling facility structure where you want to store messages when you
used shared queues.
- The value cannot have more than 12 characters, it must start with an uppercase letter (A - Z),
and can include only the characters A - Z and 0 - 9.
- The name of the queue sharing group to which the queue manager is connected is prefixed to the
name you supply. The name of the queue sharing group is always 4 characters, padded with the at
sign, @, if necessary. For example, if we use a queue sharing group that is named
NY03 and you supply the name PRODUCT7, the
resultant coupling facility structure name is NY03PRODUCT7. Note the
administrative structure for the queue sharing group (in this case
NY03CSQ_ADMIN) cannot be used for storing messages.
- For local and model queues, the following rules apply. The rules apply if you create a queue
without specifying the noReplace optional query parameter, or if you change the queue:
- On a local queue with a disposition value of shared,
structureName cannot change. If you need to change the
structureName or the disposition, you must delete and
redefine the queue. To preserve any of the messages on the queue, you must offload the messages
before you delete the queue. Reload the messages after you redefine the queue, or move the messages
to another queue.
- On a model queue with a definitionType value of
sharedDynamic, the structureName cannot be blank.
- For local and model queues, when you create a queue with the noReplace
optional query parameter, the following rules apply:
- On a local queue with a disposition value of shared, or a
model queue with a definitionType value of sharedDynamic, the
structureName cannot be blank.
dataCollection
The dataCollection object can contain the following attributes that relate to
the collection of data, monitoring, and statistics:
- accounting
- String.
- Specifies whether accounting data is collected for the queue.
- The value must be one of the following values:
- asQmgr
- Specifies that the queue inherits the value from the queue manager MQSC parameter
ACCTQ.
- off
- Specifies that accounting data is not collected for the queue.
- on
- Specifies that accounting data is collected for the queue if the ACCTQ MQSC
parameter on the queue manager is not set to none.
- monitoring
- String.
- Specifies whether online monitoring data is to be collected, and if so, the rate at which the
data is collected.
- The value must be one of the following values:
- off
- Specifies that online monitoring data is not collected for the queue.
- asQmgr
- Specifies that the queue inherits the value from the queue manager MQSC parameter
MONQ.
- low
- Specifies that online monitoring data is collected for the queue if the MONQ
MQSC parameter on the queue manager is not set to none. The rate of data collection is low.
- medium
- Specifies that online monitoring data is collected for the queue if the MONQ
MQSC parameter on the queue manager is not set to none. The rate of data collection is
moderate.
- high
- Specifies that online monitoring data is collected for the queue if the MONQ
MQSC parameter on the queue manager is not set to none. The rate of data collection is high.
- statistics
- This attribute is only available on the IBM MQ Appliance, UNIX, Linux , and Windows.
- String.
- Specifies whether statistics data is to be collected for the queue.
- The value must be one of the following values:
- asQmgr
- Specifies that the queue inherits the value from the queue manager STATQ MQSC
parameter.
- off
- Specifies that statistics data is not collected for the queue.
- on
- Specifies that statistics data is collected for the queue if the STATQ MQSC
parameter on the queue manager is not set to none.
storage
The storage object can contain the following attributes that relate to message
storage:
- indexType
- This attribute is only available on z/OS.
- String.
- Specifies the type of index that is maintained by the queue manager to expedite MQGET operations
on the queue. For shared queues, the type of index determines what type of MQGET calls can be
used.
- The value must be one of the following values:
- none
- Specifies that there is no index. Messages are retrieved sequentially.
- correlationId
- Specifies that the queue is indexed by using correlation identifiers.
- groupId
- Specifies that the queue is indexed by using group identifiers.
- messageId
- Specifies that the queue is indexed by using message identifiers.
- messageToken
- Specifies that the queue is indexed by using message tokens.
- The default value is none.
- maximumDepth
- Integer.
- Specifies the maximum number of messages that are allowed on the queue.
- The value must be in the range 0 - 999,999,999.
- maximumMessageLength
- Integer.
- Specifies the maximum message length that is allowed for messages on the queue.
- Do not set a value that is greater than the maximumMessageLength attribute
for the queue manager.
- The value must be in the range 0 - 104,857,600 bytes.
- messageDeliverySequence
- String.
- Specifies whether messages are delivered in priority order or by sequence.
- The value must be one of the following values:
- priority
- Specifies that messages are returned in priority order.
- fifo
- Specifies that messages are returned in first in, first out order.
- nonPersistentMessageClass
- This attribute is only available on the IBM MQ Appliance, UNIX, Linux, and Windows.
- String.
- This attribute is valid only on local and model queues.
- Specifies the level of reliability to be assigned to non-persistent messages that are put to the
queue.
- The value must be one of the following values:
- normal
- Specifies that non-persistent messages persist for the lifetime of the queue manager session.
They are discarded if the queue manager restarts.
- high
- Specifies that the queue manager attempts to retain non-persistent messages for the lifetime of
the queue. Non-persistent messages might still be lost if a failure occurs.
- storageClass
- This attribute is only available on z/OS.
- String.
- Specifies the name of the storage class.
general
The general object can contain the following attributes that relate to general
queue properties:
- description
- String.
- Specifies a description for the queue.
- The characters in the description field are converted from UTF-8 into the CCSID of the queue
manager. Ensure that we use only the characters that can be converted. Certain characters must be escaped:
- Double quotation marks, ", must be escaped as \"
- A backslash, \, must be escaped as \\
- A forward slash, /, must be escaped as \/
- inhibitGet
- Boolean.
- Specifies whether get operations are allowed on the queue.
- If the value is set to true, get operations are not allowed on the queue.
- inhibitPut
- Boolean.
- Specifies whether put operations are allowed on the queue.
- If the value is set to true, put operations are not allowed on the queue.
- isTransmissionQueue
- String.
- Specifies whether the queue is for normal usage or for transmitting messages to a remote queue
manager.
- If the value is set to true, the queue is a transmission queue for transmitting
messages to a remote queue manager.
- The isTransmissionQueue attribute must not normally be changed
while messages are on the queue. The format of messages changes when they are put on a transmission
queue.
extended
The extended object can contain the following attributes that relate to extended
queue properties:
- allowSharedInput
- Boolean.
- Specifies whether multiple instances of applications can open the queue for input.
- If the value is set to true, multiple instances of applications can open the
queue for input.
- backoutRequeueQueueName
- String.
- Specifies the name of the queue to which a message is transferred if it is backed out more times
than the value of backoutThreshold.
- The backout queue does not need to exist when the queue is created, but it must exist when the
backoutThreshold value is exceeded.
- backoutThreshold
- Integer.
- Specifies the number of times that a message can be backed out before it is transferred to the
backout queue that is specified by the backoutRequeueQueueName attribute.
- If the backoutThreshold value is later reduced, messages that are already
on the queue that were backed out at least as many times as the new value remain on the queue. Those
messages are transferred if they are backed out again.
- The value must be a value in the range 0 - 999,999,999.
- custom
- String.
- Specifies custom attributes for new features.
- This attribute contains the values of attributes, as pairs of attribute name and value, which
are separated by at least one space. The attribute name-value pairs have the form
NAME(VALUE). Single quotation marks, ', must be escaped with another single
quotation mark.
- enableMediaImageOperations
- This attribute is available only on the IBM MQ Appliance, UNIX, Linux, and Windows.
- Specifies whether a local or permanent dynamic queue object is recoverable from a media image,
if linear logging is being used.
- String.
- The value must be one of the following values:
- yes
- Specifies that this queue object is recoverable.
- no
- The rcdmqimg and rcrmqobj commands are not permitted for these
objects. If automatic media images are enabled, the media images are not written for these objects.
- asQmgr
- Specifies that the queue inherits the value from the queue manager ImageRecoverQueue attribute.
- This is the default value for this attribute.
- hardenGetBackout
- This attribute is only available on z/OS.
- Boolean.
- Specifies whether the count of the number of times that a message was backed out is saved, to
ensure that it is accurate across restarts of the queue manager.
- If the value is set to true, the backout count is always accurate across
restarts of the queue manager.
- supportDistributionLists
- This attribute is only available on the IBM MQ Appliance, UNIX, Linux, and Windows.
- Boolean.
- Specifies whether distribution-list messages can be placed on the queue.
- If the value is set to true, distribution lists can be placed on the
queue.