MQQueueManager.NET class

Use MQQueueManager to connect to a queue manager and access queue manager objects. It also controls transactions. The MQQueueManager constructor creates either a client or server connection.


Class

System.Object
        |
        └─ IBM.WMQ.MQBase
                |
                └─ IBM.WMQ.MQBaseObject
                        |
                        └─ IBM.WMQ.ManagedObject
                                |
                                └─ IBM.WMQ.MQQueueManager
public class IBM.WMQ.MQQueueManager extends IBM.WMQ.MQManagedObject;


Properties

Test for MQException being thrown when getting properties.

    public int AccountingConnOverride {get;}
    Whether applications can override the setting of the MQI accounting and queue accounting values.

    public int AccountingInterval {get;}
    How long before intermediate accounting records are written (in seconds).

    public int ActivityRecording {get;}
    Controls the generation of activity reports.

    public int AdoptNewMCACheck {get;}
    Specifies which elements are checked to determine whether the MCA is adopted when a new inbound channel is detected. To be adopted, the MCA name must match the name of an active MCA.

    public int AdoptNewMCAInterval {get;}
    The amount of time, in seconds, that the new channel waits for the orphaned channel to end.

    public int AdoptNewMCAType {get;}
    Whether an orphaned MCA instance is to be adopted (restarted) when a new inbound channel request is detected matching the AdoptNewMCACheck value.

    public int BridgeEvent {get;}
    Whether IMS bridge events are generated.

    public int ChannelEvent {get;}
    Whether channel events are generated.

    public int ChannelInitiatorControl {get;}
    Whether the channel initiator starts automatically when the queue manager starts.

    public int ChannelInitiatorAdapters {get;}
    The number of adapter subtasks to process IBM MQ calls.

    public int ChannelInitiatorDispatchers {get;}
    The number of dispatchers to use for the channel initiator.

    public int ChannelInitiatorTraceAutoStart {get;}
    Specifies whether the channel initiator trace starts automatically.

    public int ChannelInitiatorTraceTableSize {get;}
    The size, in megabytes, of the trace data space of a channel initiator.

    public int ChannelMonitoring {get;}
    Whether channel monitoring is used.

    public int ChannelStatistics {get;}
    Controls the collection of statistics data for channels.

    public int CharacterSet {get;}
    Returns the coded character set identifier (CCSID) of the queue manager. CharacterSet is used by the queue manager for all character string fields in the application programming interface.

    public int ClusterSenderMonitoring {get;}
    Controls the collection of online monitoring data for automatically defined cluster sender channels.

    public int ClusterSenderStatistics {get;}
    Controls the collection of statistics data for automatically defined cluster sender channels.

    public int ClusterWorkLoadMRU {get;}
    The maximum number of outbound cluster channels.

    public int ClusterWorkLoadUseQ {get;}
    The default value of the MQQueue property, ClusterWorkLoadUseQ, if it specifies a value of QMGR.

    public int CommandEvent {get;}
    Specifies whether command events are generated.

    public string CommandInputQueueName {get;}
    Returns the name of the command input queue defined on the queue manager. Applications can send commands to this queue, if authorized to do so.

    public int CommandLevel {get;}
    Indicates the function level of the queue manager. The set of functions that correspond to a particular function level depends on the platform. On a particular platform, we can rely on every queue manager supporting the functions at the lowest functional level common to all the queue managers.

    public int CommandLevel {get;}
    Whether the command server starts automatically when the queue manager starts.

    public string DNSGroup {get;}
    No longer used.

    public int DNSWLM {get;}
    No longer used.

    public int IPAddressVersion {get;}
    Which IP protocol (IPv4 or IPv6) to use for a channel connection.

    public boolean IsConnected {get;}
    Returns the value of the isConnected.
    If true, a connection to the queue manager has been made, and is not known to be broken. Any calls to IsConnected do not actively attempt to reach the queue manager, so it is possible that physical connectivity can break, but IsConnected can still return true. The IsConnected state is only updated when activity, for example, putting a message, getting a message, is performed on the queue manager.
    If false, a connection to the queue manager has not been made, or has been broken, or has been disconnected.

    public int KeepAlive {get;}
    Specifies whether the TCP KEEPALIVE facility is to be used to check that the other end of the connection is still available. If it is unavailable, the channel is closed.

    public int ListenerTimer {get;}
    The time interval, in seconds, between attempts by IBM MQ to restart the listener after an APPC or TCP/IP failure.

    public int LoggerEvent {get;}
    Whether logger events are generated.

    public string LU62ARMSuffix {get;}
    The suffix of the APPCPM member of SYS1.PARMLIB. This suffix nominates the LUADD for this channel initiator. When automatic restart manager (ARM) restarts the channel initiator, the z/OS® command SET APPC=xx is issued.

    public string LUGroupName {get; z/os}
    The generic LU name to be used by the LU 6.2 listener that handles inbound transmissions for the queue sharing group.

    public string LUName {get;}
    The name of the LU to use for outbound LU 6.2 transmissions.

    public int MaximumActiveChannels {get;}
    The maximum number of channels that can be active at any time.

    public int MaximumCurrentChannels {get;}
    The maximum number of channels that can be current at any time (including server-connection channels with connected clients).

    public int MaximumLU62Channels {get;}
    The maximum number of channels that can be current, or clients that can be connected, that use the LU 6.2 transmission protocol.

    public int MaximumMessageLength {get;}
    Returns the maximum length of a message (in bytes) that can be handled by the queue manager. No queue can be defined with a maximum message length greater than MaximumMessageLength.

    public int MaximumPriority {get;}
    Returns the maximum message priority supported by the queue manager. Priorities range from zero (lowest) to this value. Throws MQException if you call this method after disconnecting from the queue manager.

    public int MaximumTCPChannels {get;}
    The maximum number of channels that can be current, or clients that can be connected, that use the TCP/IP transmission protocol.

    public int MQIAccounting {get;}
    Controls the collection of accounting information for MQI data.

    public int MQIStatistics {get;}
    Controls the collection of statistics monitoring information for the queue manager.

    public int OutboundPortMax {get;}
    The maximum value in the range of port numbers to be used when binding outgoing channels.

    public int OutboundPortMin {get;}
    The minimum value in the range of port numbers to be used when binding outgoing channels.

    public int QueueAccounting {get;}
    Whether class 3 accounting (thread-level and queue-level accounting) data is to be used for all queues.

    public int QueueMonitoring {get;}
    Controls the collection of online monitoring data for queues.

    public int QueueStatistics {get;}
    Controls the collection of statistics data for queues.

    public int ReceiveTimeout {get;}
    The length of time that a TCP/IP channel waits to receive data, including heartbeats, from its partner before returning to the inactive state.

    public int ReceiveTimeoutMin {get;}
    The minimum length of time that a TCP/IP channel waits to receive data, including heartbeats, from its partner before returning to an inactive state.

    public int ReceiveTimeoutType {get;}
    The qualifier to apply to the value in ReceiveTimeout.

    public int SharedQueueQueueManagerName {get;}
    Specifies how to deliver messages to a shared queue. If the put specifies a different queue manager from the same queue sharing group as the target queue manager, the message is delivered in two ways:

      MQC.MQSQQM_USE
      Messages are delivered to the object queue manager before being put on the shared queue.

      MQCMQSQQM_IGNORE
      Messages are put directly on the shared queue.

    public int SSLEvent {get;}
    Whether TLS events are generated.

    public int SSLFips {get;}
    Whether only FIPS-certified algorithms are to be used if cryptography is performed in IBM MQ, rather than cryptographic hardware.

    public int SSLKeyResetCount {get;}
    Indicates the number of unencrypted bytes sent and received within a TLS conversation before the secret key is renegotiated.

    public int ClusterSenderStatistics {get;}
    Specifies the interval, in minutes, between consecutive gatherings of statistics.

    public int SyncpointAvailability {get;}
    Indicates whether the queue manager supports units of work and sync points with the MQQueue.get and MQQueue.put methods.

    public string TCPName {get;}
    The name of either the only, or default, TCP/IP system to be used, depending on the value of TCPStackType.

    public int TCPStackType {get;}
    Specifies whether the channel initiator uses only the TCP/IP address space specified in TCPName. Alternatively, the channel initiator can bind to any TCP/IP address.

    public int TraceRouteRecording {get;}
    Controls the recording of route tracing information.


Methods

    public MQProcess AccessProcess(string processName, int openOptions);

    public MQProcess AccessProcess(string processName, int openOptions, string queueManagerName, string alternateUserId);

    Throws MQException.

    Access an IBM MQ process on this queue manager to inquire on process attributes.

      processName
      The name of the process to open.
      openOptions
      Options that control the opening of the process. The valid options that can be added, or combined using a bitwise OR, are:

      • MQC.MQOO_FAIL_IF_QUIESCING
      • MQC.MQOO_INQUIRE
      • MQC.MQOO_SET
      • MQC.MQOO_ALTERNATE_USER_AUTHORITY
      queueManagerName
      The name of the queue manager on which the process is defined. We can leave a blank or null queue manager name if the queue manager is the same as the one the process is accessing.
      alternateUserId

      If MQC.MQOO_ALTERNATE_USER_AUTHORITY is specified in the openOptions parameter, alternateUserId specifies the alternative user ID used to check the authorization for the action. If MQOO_ALTERNATE_USER_AUTHORITY is not specified, alternateUserId can be blank or null.

      Default user authority is used for connection to the queue manager if MQC.MQOO_ALTERNATE_USER_AUTHORITY is not specified.

    public MQQueue AccessQueue(string queueName, int openOptions);

    public MQQueue AccessQueue(string queueName, int openOptions, string queueManagerName, string dynamicQueueName, string alternateUserId);

    Throws MQException.

    Accesses a queue on this queue manager.

    We can get or browse messages, put messages, inquire about the attributes of the queue or set the attributes of the queue. If the queue named is a model queue, a dynamic local queue is created. Query the name attribute of the resultant MQQueue object to find out the name of the dynamic queue.

      queueName
      Name of queue to open.
      openOptions
      Options that control the opening of the queue.

        MQC.MQOO_ALTERNATE_USER_AUTHORITY
        Validate with the specified user identifier.

        MQC.MQOO_BIND_AS_QDEF
        Use default binding for queue.

        MQC.MQOO_BIND_NOT_FIXED
        Do not bind to a specific destination.

        MQC.MQOO_BIND_ON_OPEN
        Bind handle to destination when queue is opened.

        MQC.MQOO_BROWSE
        Open to browse message.

        MQC.MQOO_FAIL_IF_QUIESCING
        Fail if the queue manager is quiescing.

        MQC.MQOO_INPUT_AS_Q_DEF
        Open to get messages using queue-defined default.

        MQC.MQOO_INPUT_SHARED
        Open to get messages with shared access.

        MQC.MQOO_INPUT_EXCLUSIVE
        Open to get messages with exclusive access.

        MQC.MQOO_INQUIRE
        Open for inquiry - required if you want to query properties.

        MQC.MQOO_OUTPUT
        Open to put messages.

        MQC.MQOO_PASS_ALL_CONTEXT
        Allow all context to be passed.

        MQC.MQOO_PASS_IDENTITY_CONTEXT
        Allow identity context to be passed.

        MQC.MQOO_SAVE_ALL_CONTEXT
        Save context when message retrieved.

        MQC.MQOO_SET
        Open to set attributes - required if you want to set properties.

        MQC.MQOO_SET_ALL_CONTEXT
        Allows all context to be set.

        MQC.MQOO_SET_IDENTITY_CONTEXT
        Allows identity context to be set.

      queueManagerName
      Name of the queue manager on which the queue is defined. A name that is entirely blank or null denotes the queue manager to which the MQQueueManager object is connected.
      dynamicQueueName
      dynamicQueueName is ignored unless queueName specifies the name of a model queue. If it does, dynamicQueueName specifies the name of the dynamic queue to be created. A blank or null name is not valid if queueName specifies the name of a model queue. If the last nonblank character in the name is an asterisk, *, the queue manager replaces the asterisk with a string of characters. The characters guarantee that the name generated for the queue is unique on this queue manager.
      alternateUserId
      If MQC.MQOO_ALTERNATE_USER_AUTHORITY is specified in the openOptions parameter, alternateUserId specifies the alternate user identifier that is used to check the authorization for the open. If MQC.MQOO_ALTERNATE_USER_AUTHORITY is not specified, alternateUserId can be left blank, or null.

    public MQTopic AccessTopic( MQDestination destination, string topicName, string topicObject, int options);

    public MQTopic AccessTopic( MQDestination destination, string topicName, string topicObject, int options, string alternateUserId);

    public MQTopic AccessTopic( MQDestination destination, string topicName, string topicObject, int options, string alternateUserId, string subscriptionName);

    public MQTopic AccessTopic( MQDestination destination, string topicName, string topicObject, int options, string alternateUserId, string subscriptionName, System.Collections.Hashtable properties);

    public MQTopic AccessTopic(string topicName, string topicObject, int openAs, int options);

    public MQTopic AccessTopic(string topicName, string topicObject, int openAs, int options, string alternateUserId);

    public MQTopic AccessTopic(string topicName, string topicObject, int options, string alternateUserId, string subscriptionName);

    public MQTopic AccessTopic(string topicName, string topicObject, int options, string alternateUserId, string subscriptionName, System.Collections.Hashtable properties);

    Access a topic on this queue manager.

    MQTopic objects are closely related to administrative topic objects, which are sometimes called topic objects. On input, topicObject points to an administrative topic object. The MQTopic constructor obtains a topic string from the topic object and combines it with topicName to create a topic name. Either or both topicObject or topicName can be null. The topic name is matched to the topic tree, and the name of the closest matching administrative topic object is returned in topicObject.

    The topics that are associated with the MQTopic object are the result of combining two topic strings. The first topic string is defined by the administrative topic object identified by topicObject. The second topic string is topicString. The resulting topic string associated with the MQTopic object can identify multiple topics by including wildcards.

    Depending on whether the topic is opened for publishing or subscribing, we can use the MQTopic.Put methods to publish on topics, or MQTopic.Get methods to receive publications on topics. If you want to publish and subscribe to the same topic, you must access the topic twice, once for publish and once for subscribe.

    If you create an MQTopic object for subscription, without providing an MQDestination object, a managed subscription is assumed. If you pass a queue as an MQDestination object, an unmanaged subscription is assumed. You must ensure the subscription options you set are consistent with the subscription being managed or unmanaged.

      destination
      destination is an MQQueue instance. By providing destination, MQTopic is opened as an unmanaged subscription. Publications on the topic are delivered to the queue accessed as destination.
      topicName
      A topic string that is the second part of the topic name. topicName is concatenated with the topic string defined in the topicObject administrative topic object. We can set topicName to null, in which case the topic name is defined by the topic string in topicObject.
      topicObject
      On input, topicObject is the name of the topic object that contains the topic string that forms the first part of the topic name. The topic string in topicObject is concatenated with topicName. The rules for constructing topic strings are defined in Combining topic strings.
      On output, topicObject contains the name of the administrative topic object that is the closest match in the topic tree to the topic identified by the topic string.
      openAs
      Access the topic to publish or subscribe. The parameter can contain only one of these options:

      • MQC.MQTOPIC_OPEN_AS_SUBSCRIPTION
      • MQC.MQTOPIC_OPEN_AS_PUBLICATION
      options

      Combine the options that control the opening of the topic for either publication or subscription. Use MQC.MQSO_* constants to access a topic for subscription and MQC.MQOO_* constants to access a topic for publication.

      If more than one option is required, add the values together, or combine the option values using the bitwise OR operator.

      alternateUserId
      Specify the alternate user ID that is used to check for the required authorization to finish the operation. You must specify alternateUserId, if either MQC.MQOO_ALTERNATE_USER_AUTHORITY or MQC.MQSO_ALTERNATE_USER_AUTHORITY is set in the options parameter.
      subscriptionName
      subscriptionName is required if the options MQC.MQSO_DURABLE or MQC.MQSO_ALTER are provided. In both cases, MQTopic is implicitly opened for subscription. An exception is thrown if the MQC.MQSO_DURABLE is set, and the subscription exists, or if MQC.MQSO_ALTER is set, and the subscription does not exist.
      properties
      Set any of the special subscription properties listed using a hash table. Specified entries in the hash table are updated with output values. Entries are not added to the hash table to report output values.

      • MQC.MQSUB_PROP_ALTERNATE_SECURITY_ID
      • MQC.MQSUB_PROP_SUBSCRIPTION_EXPIRY
      • MQC.MQSUB_PROP_SUBSCRIPTION_USER_DATA
      • MQC.MQSUB_PROP_SUBSCRIPTION_CORRELATION_ID
      • MQC.MQSUB_PROP_PUBLICATION_PRIORITY
      • MQC.MQSUB_PROP_PUBLICATION_ACCOUNTING_TOKEN
      • MQC.MQSUB_PROP_PUBLICATION_APPLICATIONID_DATA

    public MQAsyncStatus GetAsyncStatus();

    Throws MQException

    Returns an MQAsyncStatus object, which represents the asynchronous activity for the queue manager connection.

    public void Backout();

    Throws MQException.

    Backout any messages that were read or written within sync point since the last sync point.

    Messages that were written with the MQC.MQPMO_SYNCPOINT flag set are removed from queues. Messages read with the MQC.MQGMO_SYNCPOINT flag are reinstated on the queues they came from. If the messages are persistent, the changes are logged.

    For reconnectable clients, the MQRC_NONE reason code is returned to a client after reconnection is successful.

    public void Begin();

    Throws MQException.

    Begin is supported only in server bindings mode. It starts a global unit of work.

    public void Commit();

    Throws MQException.

    Commit any messages that were read or written within sync point since the last sync point.

    Messages written with the MQC.MQPMO_SYNCPOINT flag set are made available to other applications. Messages retrieved with the MQC.MQGMO_SYNCPOINT flag set are deleted. If the messages are persistent, the changes are logged.

    The following reason codes are returned to a reconnectable client:

    • MQRC_CALL_INTERRUPTED if connection is lost while carrying out the commit call.
    • MQRC_BACKED_OUT if the commit call is issued after reconnection.

    Disconnect();

    Throws MQException.

    Close the connection to the queue manager. All objects accessed on this queue manager are not longer accessible to this application. To reaccess the objects, create a MQQueueManager object.

    Generally, any work performed as part of a unit of work is committed. However, if the unit of work is managed by .NET, the unit of work might be rolled back.

    public void Put(int type, string destinationName, MQMessage message);

    public void Put(int type, string destinationName, MQMessage message MQPutMessageOptions putMessageOptions);

    public void Put(int type, string destinationName, string queueManagerName, string topicString, MQMessage message);

    public void Put(string queueName, MQMessage message);

    public void Put(string queueName, MQMessage message, MQPutMessageOptions putMessageOptions);

    public void Put(string queueName, string queueManagerName, MQMessage message);

    public void Put(string queueName, string queueManagerName, MQMessage message, MQPutMessageOptions putMessageOptions);

    public void Put(string queueName, string queueManagerName, MQMessage message, MQPutMessageOptions putMessageOptions, string alternateUserId);

    Throws MQException.

    Places a single message onto a queue or topic without creating an MQQueue or MQTopic object first.

      queueName
      The name of the queue onto which to place the message.
      destinationName
      The name of a destination object. It is either a queue or a topic depending on the value of type.
      type
      The type of destination object. You must not combine the options.

        MQC.MQOT_Q
        Queue

        MQC.MQOT_TOPIC
        Topic

      queueManagerName

      The name of the queue manager or queue manager alias, on which the queue is defined. If type MQC.MQOT_TOPIC is specified this parameter is ignored.

      If the queue is a model queue, and the resolved queue manager name is not this queue manager, an MQException is thrown.

      topicString

      topicString is combined with the topic name in the destinationName topic object.

      topicString is ignored if destinationName is a queue.

      message
      The message to send. Message is an input/output object.
      The following reason codes are returned to a reconnectable client:

      • MQRC_CALL_INTERRUPTED if the connection is broken while performing a Put call on a persistent message.
      • MQRC_NONE if the connection is successful while performing a Put call on a non-persistent message (see Application Recovery ).
      putMessageOptions

      Options controlling the actions of the put.

      If you omit putMessageOptions, a default instance of putMessageOptions is created. putMessageOptions is an input/output object.

      If we use the MQPMO_LOGICAL_ORDER option in a reconnectable client, the MQRC_RECONNECT_INCOMPATIBLE reason code is returned.

      alternateUserId

      Specifies an alternate user identifier used to check authorization when placing the message on a queue.

      We can omit alternateUserId if we do not set MQC.MQOO_ALTERNATE_USER_AUTHORITY in putMessageOptions. If you set MQC.MQOO_ALTERNATE_USER_AUTHORITY, you must also set alternateUserId. alternateUserId has not effect unless you also set MQC.MQOO_ALTERNATE_USER_AUTHORITY.


Constructors

    public MQQueueManager();

    public MQQueueManager(string queueManagerName);

    public MQQueueManager(string queueManagerName, Int options);

    public MQQueueManager(string queueManagerName, Int options, string channel, string connName);

    public MQQueueManager(string queueManagerName, string channel, string connName);

    public MQQueueManager(string queueManagerName, System.Collections.Hashtable properties);

    Throws MQException.

    Creates a connection to a queue manager. Select between creating a client connection or a server connection.

    You must have inquire ( inq) authority on the queue manager when attempting to connect to the queue manager. Without inquire authority, the connection attempt fails.

    A client connection is created if one of the following conditions is true:

    1. channel or connName are specified in the constructor.
    2. HostName, Port, or Channel are specified in properties.
    3. MQEnvironment.HostName, MQEnvironment.Port, or MQEnvironment.Channel are specified.

    The values of the connection properties are defaulted in the order shown. The channel and connName in the constructor take precedence over the property values in the constructor. The constructor property values take precedence of the MQEnvironment properties.

    The host name, channel name, and port are defined in the MQEnvironment class.

      queueManagerName
      Name of the queue manager, or queue manager group to connect to.
      Omit the parameter, or leave it null, or blank to make a default queue manager selection. The default queue manager connection on a server is to the default queue manager on the server. The default queue manager connection on a client connection is to the queue manager the listener is connected to.
      options
      Specify MQCNO connection options. The values must be applicable to the type of connection being made. For example, if you specify the following server connection properties for a client connection an MQException is thrown.

      • MQC.MQCNO_FASTPATH_BINDING
      • MQC.MQCNO_STANDARD_BINDING
      properties
      The properties parameter takes a series of key/value pairs that override the properties set by MQEnvironment ; see the example, Override MQEnvironment properties. The following properties can be overridden:

      • MQC.CONNECT_OPTIONS_PROPERTY
      • MQC.CONNNECTION_NAME_PROPERTY
      • MQC.ENCRYPTION_POLICY_SUITE_B
      • MQC.HOST_NAME_PROPERTY
      • MQC.PORT_PROPERTY
      • MQC.CHANNEL_PROPERTY
      • MQC.SSL_CIPHER_SPEC_PROPERTY
      • MQC.SSL_PEER_NAME_PROPERTY
      • MQC.SSL_CERT_STORE_PROPERTY
      • MQC.SSL_CRYPTO_HARDWARE_PROPERTY
      • MQC.SECURITY_EXIT_PROPERTY
      • MQC.SECURITY_USERDATA_PROPERTY
      • MQC.SEND_EXIT_PROPERTY
      • MQC.SEND_USERDATA_PROPERTY
      • MQC.RECEIVE_EXIT_PROPERTY
      • MQC.RECEIVE_USERDATA_PROPERTY
      • MQC.USER_ID_PROPERTY
      • MQC.PASSWORD_PROPERTY
      • MQC.MQAIR_ARRAY
      • MQC.KEY_RESET_COUNT
      • MQC.FIPS_REQUIRED
      • MQC.HDR_CMP_LIST
      • MQC.MSG_CMP_LIST
      • MQC.TRANSPORT_PROPERTY
      channel
      Name of a server connection channel
      connName
      Connection name in the format HostName (Port.

      We can supply a list of hostnames and ports as an argument to the constructor MQQueueManager (String queueManagerName, Hashtable properties) using CONNECTION_NAME_PROPERTY.

      For example:

      ConnectionName = "fred.mq.com(2344),nick.mq.com(3746),tom.mq.com(4288)";

      Hashtable Properties-new Hashtable();

      properties.Add(MQC.CONNECTION_NAME_PROPERTY,ConnectionName);

      MQQueueManager qmgr=new MQQueue Manager("qmgrname",properties);

      When a connection attempt is made, the connection name list is processed in order. If the connection attempt to the first host name and port fails, then connection to the second pair of attributes is attempted. The client repeats this process until either a successful connection is made or the list is exhausted. If the list is exhausted, an appropriate reason code and completion code is returned to the client application.

      When a port number is not provided for the connection name, the default port (configured in mqclient.ini ) is used.


Set the Connection List

We can set the connection list by using the following methods when the automatic client reconnection options are set:

    Set the connection list through MQSERVER
    We can set the connection list through the command prompt.

    At the command prompt, set the following command:

    MQSERVER=SYSTEM.DEF.SVRCONN/TCP/Hostname1(Port1),Hostname2(Por2),Hostname3(Port3)
    
    For example:
    MQSERVER=SYSTEM.DEF.SVRCONN/TCP/fred.mq.com(5266),nick.mq.com(6566),jack.mq.com(8413)
    

    If you set the connection in the MQSERVER, do not set it in the application.

    If you set the connection list in the application, the application overwrites whatever is set in the MQSERVER environment variable.

    Set the connection list through the application
    We can set the connection list in the application by specifying the host name and port properties.
    String connName = "fred.mq.com(2344), nick.mq.com(3746), chris.mq.com(4288)";
    MQQueueManager qm = new MQQueueManager("QM1", "TestChannel", connName);
    

    Set the connection list through app.config
    App.config is an XML file where you specify the key-value pairs.

    In the connection list specify

    <app.Settings>
    <add key="Connection1" value="Hostname1(Port1)"/>
    <add key="Connection2" value="Hostname2(Port2)"/>
    <app.Settings>
    
    For example:
    <app.Settings>
    <add key>="Connection1" value="fred.mq.com(2966)"/>
    <add key>="Connection2" value="alex.mq.com(6533)"/>
    <app.Settings>
    

    We can directly change the connection list in the app.config file.

    Set the connection list through MQEnvironment
    To set the Connection list through the MQEnvironment, use the ConnectionName property.
    MQEnvironment.ConnectionName = "fred.mq.com(4288),"alex.mq.com(5211);
    

    The ConnectionName property overwrites the host name and port properties set in the MQEnvironment.


Create a client connection

The following example shows you how to create a client connection to a queue manager. We can create a client connection by setting the MQEnvironment variables before creating a new MQQueueManager Object.

Figure 1. Client connection
MQEnvironment.Hostname = "fred.mq.com";  // host to connect to
MQEnvironment.Port     = 1414;           // port to connect to
                                         //If not explicitly set,
                                         // defaults to 1414
                                         // (the default IBM MQ port)
MQEnvironment.Channel  = "channel.name"; // the case sensitive
                                         //  name of the
                                         // SVR CONN channel on
                                         // the queue manager
MQQueueManager qMgr    = new MQQueueManager("MYQM");


Override MQEnvironment properties

The following example shows you how to create a queue manager with its user ID and password defined in a hash table.

Figure 2. Overriding MQEnvironment properties
Hashtable properties = new Hashtable();

properties.Add( MQC.USER_ID_PROPERTY, "ExampleUserId" );
properties.Add( MQC.PASSWORD_PROPERTY, "ExamplePassword" );

try
{
    MQQueueManager qMgr = new MQQueueManager("qmgrname", properties);
}
catch (MQException mqe) 
{
    System.Console.WriteLine("Connect failed with " + mqe.Message);
    return((int)mqe.Reason);
}


Create a reconnectable connection

The following example shows you how to automatically reconnect a client to a Queue Manager.

Figure 3. Automatically reconnecting a client to a queue manager
Hashtable properties = new Hashtable(); // The queue manager name and the 
                                 // properties how it has to be connected

properties.Add(MQC.CONNECT_OPTIONS_PROPERTY, MQC.MQCNO_RECONNECT); // Options 
                                 // through which reconnection happens

properties.Add(MQC.CONNECTION_NAME_PROPERTY,"fred.mq.com(4789),nick.mq.com(4790)"); // The list 
                                 // of queue managers through which reconnection happens

MQ QueueManager qmgr = new MQQueueManager("qmgrname", properties);