c# IBM.WMQ;
时间: 2024-12-27 08:29:01 浏览: 19
### 使用C#与IBM MQ进行消息队列操作
#### 创建连接工厂实例
为了通过C#应用程序访问IBM MQ,首先需要创建`MQQueueManager`对象来管理到队列管理器的连接。这通常涉及设置主机名、通道名称和其他必要的参数。
```csharp
using IBM.WMQ;
// 设置属性用于建立连接
var properties = new Hashtable();
properties.Add(MQC.HOST_NAME_PROPERTY, "hostname");
properties.Add(MQC.CHANNEL_PROPERTY, "channelName");
properties.Add(MQC.PORT_PROPERTY, portNumber);
properties.Add(MQC.TRANSPORT_PROPERTY, MQC.TRANSPORT_MQSERIES_CLIENT);
// 建立队列管理器连接
MQQueueManager qmgr = new MQQueueManager("QM_Name", properties);
```
此代码片段展示了如何配置客户端模式下的连接属性,并初始化一个新的`MQQueueManager`实例[^4]。
#### 打开现有队列或主题
一旦建立了与队列管理器的成功连接,则可以通过指定其名称打开特定的队列或主题来进行发送或接收消息的操作:
对于持久化订阅者而言,在选项中加入了`MQSO_DURABLE`标志位以确保即使当订阅者断线重连之后仍然能够接收到之前错过的消息[^1]。
```csharp
int openOptionsForGet = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_FAIL_IF_QUIESCING;
string queueName = "QUEUE.NAME";
MQQueue queue = qmgr.AccessQueue(queueName, openOptionsForGet);
```
上述例子说明了怎样利用默认输入方式打开一个已存在的本地队列以便从中获取数据项;而针对发布/订阅模型中的主题则需调用不同的API方法如`AccessTopic()`。
#### 发送和接收消息
向队列写入新消息以及从其中读取消息都是围绕着`MQMessage`类展开的工作。下面给出了一组简单的示例函数用来展示这两个过程的具体实现细节:
- **发送消息**
```csharp
public void SendMessage(string msgText)
{
using (MQQueue queue = qmgr.AccessQueue("DEST_QUEUE", MQC.MQOO_OUTPUT))
{
var message = new MQMessage { Format = MQC.MQFMT_STRING };
message.WriteString(msgText);
var putMsgOpts = new MQPutMessageOptions(); // 接受默认放置选项
queue.Put(message, putMsgOpts);
}
}
```
- **接收消息**
如果希望遍历整个队列直到遇到预期条件为止(比如处理完所有待办事项),那么可以在循环体内不断尝试取出下一个可用条目直至达到终止状态。
```csharp
while(true){
try{
using(var queue=qmgr.AccessQueue("SRC_QUEUE",openOptionsForGet)){
var getMessage=new MQMessage();
var getOpts= new MQGetMessageOptions(){
Options = MQC.MQGMO_WAIT|MQC.MQGMO_NO_SYNCPOINT,
WaitInterval = 5000 //等待时间设为五秒
};
queue.Get(getMessage,getOpts);
string received=getMessage.ReadString((uint)getMessage.MessageLength);
Console.WriteLine($"Received Message:{received}");
}
}catch(Exception ex){
if(ex is MQException && ((MQException)ex).ReasonCode==2033){break;}else{throw;}
}
}
```
这段逻辑实现了持续监听源队列的动作,每当有新的项目加入时即刻打印出来显示给用户知道。同时注意捕获异常情况特别是因为超时期间内没有任何有效载荷而导致失败的情形下优雅退出轮询流程[^2]。
阅读全文