基于C#的IBM消息队列操作客户端
背景:
做XX项目需要把交易的消息推送给YY系统,技术选型MQ
另:选用MQ原因是为了防止YY系统宕机,无法接受收消息
实现
1、安装IBM WebSphere MQ客户端
2、引用amqmdnet.dll(在客户端的安装目录下可以找到)
3、C#代码如下
/*
* write by:wjf
* date:2015-05-20
* dec:MQ操作客户端
*
*/
using System;
using System.Diagnostics;
using System.IO;
using IBM.WMQ; namespace RsaTest
{
public class IbmMQClient : IDisposable
{
// 定义MQ 服务器的IP 地址;
private string hostname = "182.180.80.241";
//private const string hostname = "182.180.80.243";
//MQ侦听端口号
//private const int port = 54221;
private readonly int port;
// 设置队列打开选项为可存放;
private const int openOptions = MQC.MQOO_OUTPUT; // MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT; // 队列管理器;
private readonly MQQueueManager qManager;
//队列名称
private readonly string qName;
// 定义MQ 服务器连接通道的名称;
private readonly string channel;
// 定义队列管理器的名称;
//private string qManagerName; public IbmMQClient(string qManagerName, string channel, string qName, string sPort, string hostname)
{
//this.qManagerName = qManagerName;
this.channel = channel;
this.qName = qName;
this.port = Convert.ToInt32(sPort);
this.hostname = hostname;
InitQueueEnv();
qManager = new MQQueueManager(qManagerName);
} /// <summary>
/// 初始化队列环境
/// </summary>
private void InitQueueEnv()
{
// 初始化MQ 环境变量,以指定MQ 服务器的连接参数;
// 指定MQ 服务器的主机名称;
MQEnvironment.Hostname = hostname;
// 指定MQ 服务器的服务器连接通道的名称;
MQEnvironment.Channel = channel;
// 指定MQ 服务器的侦听器的侦听端口号;
MQEnvironment.Port = port;
//MQEnvironment.UserId = "mqm";
} public void SendMessage(string message)
{
if (qManager == null)
{
throw new Exception("队列管理器未初始化。");
}
// 获得队列的访问句柄;
MQQueue lq = qManager.AccessQueue(qName, openOptions); try
{
// 构造新的消息对象,为发送消息做准备;
MQMessage mo = new MQMessage();
//指定编码(有点小重要哦)
mo.CharacterSet = ;
// 填入消息内容;
//mo.WriteUTF(message);
mo.WriteString(message);
//指定消息的格式
mo.Format = MQC.MQFMT_STRING;
// 构造放入消息选项对象;
MQPutMessageOptions pmo = new MQPutMessageOptions();
// 向已打开队列放入已构造的测试消息;
lq.Put(mo, pmo);
}
finally
{
try
{
// 关闭本地队列;
lq.Close();
}
catch (Exception e)
{
Debug.WriteLine(e);
}
}
} public void SendFile(string filePath)
{
if (qManager == null)
{
throw new Exception("队列管理器未初始化。");
}
// 获得队列的访问句柄;
MQQueue lq = qManager.AccessQueue(qName, openOptions); try
{
// 构造新的消息对象,为发送消息做准备;
MQMessage mo = new MQMessage();
//构建文件信息对象
FileInfo fi = new FileInfo(filePath);
//写入文件大小
mo.WriteInt8(fi.Length);
//写入文件名
mo.WriteUTF(fi.Name);
//写入文件内容
mo.Write(File.ReadAllBytes(filePath));
// 构造放入消息选项对象;
MQPutMessageOptions pmo = new MQPutMessageOptions();
// 向已打开队列放入已构造的测试消息;
lq.Put(mo, pmo);
}
finally
{
try
{
// 关闭本地队列;
lq.Close();
}
catch (Exception e)
{
Debug.WriteLine(e);
}
}
} ~IbmMQClient()
{
Close();
} /// <summary>
/// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
/// </summary>
/// <filterpriority></filterpriority>
public void Dispose()
{
Close();
} public void Close()
{
if (qManager != null)
{
try
{
// 释放与队列管理器的连接;
qManager.Disconnect();
}
catch (Exception e)
{
Debug.WriteLine(e);
}
}
}
}
}
基于C#的IBM消息队列操作客户端的更多相关文章
- .NET Core微服务之基于EasyNetQ使用RabbitMQ消息队列
Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.消息队列与RabbitMQ 1.1 消息队列 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更 ...
- Delayer 基于 Redis 的延迟消息队列中间件
Delayer 基于 Redis 的延迟消息队列中间件,采用 Golang 开发,支持 PHP.Golang 等多种语言客户端. 参考 有赞延迟队列设计 中的部分设计,优化后实现. 项目链接:http ...
- linux消息队列操作
对消息队列的操作无非有以下三种类型: 1. 打开或创建消息队列消息队列的内核持续性要求每一个消息队列都在系统范围内相应唯一的键值,所以,要获得一个消息队列的描写叙述字,仅仅需提供该消息队列的键值就可以 ...
- 滴滴出行基于RocketMQ构建企业级消息队列服务的实践
小结: 1. https://mp.weixin.qq.com/s/v6NM3UgX-qTI7yO1QPCJrw 滴滴出行基于RocketMQ构建企业级消息队列服务的实践 原创: 江海挺 阿里巴巴中间 ...
- [转载] 基于Redis实现分布式消息队列
转载自http://www.linuxidc.com/Linux/2015-05/117661.htm 1.为什么需要消息队列?当系统中出现“生产“和“消费“的速度或稳定性等因素不一致的时候,就需要消 ...
- 基于redis的延迟消息队列设计
需求背景 用户下订单成功之后隔20分钟给用户发送上门服务通知短信 订单完成一个小时之后通知用户对上门服务进行评价 业务执行失败之后隔10分钟重试一次 类似的场景比较多 简单的处理方式就是使用定时任务 ...
- 基于redis的延迟消息队列设计(转)
需求背景 用户下订单成功之后隔20分钟给用户发送上门服务通知短信 订单完成一个小时之后通知用户对上门服务进行评价 业务执行失败之后隔10分钟重试一次 类似的场景比较多 简单的处理方式就是使用定时任务 ...
- 基于线程池、消息队列和epoll模型实现并发服务器架构
引言 并发是什么?企业在进行产品开发过程中为什么需要考虑这个问题?想象一下天猫的双11和京东的618活动,一秒的点击量就有几十万甚至上百万,这么多请求一下子涌入到服务器,服务器需要对这么多的请求逐个进 ...
- 基于Docker搭建分布式消息队列Kafka
本文基于Docker搭建一套单节点的Kafka消息队列,Kafka依赖Zookeeper为其管理集群信息,虽然本例不涉及集群,但是该有的组件都还是会有,典型的kafka分布式架构如下图所示.本例搭建的 ...
随机推荐
- synchronize学习
这个例子我们看到,java中将对象或者Class对象当做锁 package synchronized简单使用; public class Test7 extends Thread{ public st ...
- SSAS数据挖掘算法简介
决策树分析算法:以二叉树的形式展现,分析出影响某种行为(如购买自行车)的因素,并对这些因素排序. 聚类分析算法:物以类聚,人以群分.分析特定群体所共同含有的属性(因素). 未完,待续..
- bzoj 1226 [SDOI2009]学校食堂Dining(状压DP)
Description 小F 的学校在城市的一个偏僻角落,所有学生都只好在学校吃饭.学校有一个食堂,虽然简陋,但食堂大厨总能做出让同学们满意的菜肴.当然,不同的人口味也不一定相同,但每个人的口味都可以 ...
- uva_12535 - Probability Through Experiments
题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- 坑爹的IE quirk模式【转】
调试一个页面,ie下面页面css样式很是奇怪,各种失效.找了半天原因不知道怎么回事.最后在调试工具中发现,文档模式为quirk,改成别的(IE 7|8|9)正常. 为什么会自动选择此文档模式呢? 先看 ...
- maven依赖规则
1.就近原则,传递依赖 A-B-C -> A-C 2.先声明原则 A-B-C D-E-C 依赖的规则阻止了jar包冲突
- bzoj3926: [Zjoi2015]诸神眷顾的幻想乡 对[广义后缀自动机]的一些理解
先说一下对后缀自动机的理解,主要是对构造过程的理解. 构造中,我们已经得到了前L个字符的后缀自动机,现在我们要得到L+1个字符的后缀自动机,什么需要改变呢? 首先,子串$[0,L+1)$对应的状态不存 ...
- Spring mvc Interceptor 解决Session超时配置流程
最近公司内部框架中对Session超时这一功能未实现,由于采用iframe结构,Session超时后,当点击左侧系统菜单时,会在iframe的右侧再次弹出登陆框. 该问题是由于没有设置拦截器造成. 添 ...
- 路冉的JavaScript学习笔记-2015年2月5日
1.为Js原始值创建临时对象,并进行属性引用 var s="text"; s.len=4;//这里Js调用new String(s)的方法创建了一个临时对象,用来属性引用 cons ...
- WPF 多线程
写法3 private void button1_Click(object sender, RoutedEventArgs e) { System. ...