JAVA 调用MQ

前提:MQ服务器端创建

队列管理器:QueueManager

队列:XML.IN

服务器连接通道:SYSTEM.ADMIN.SVRCONN

监听器监听1414端口。

package mq;

import com.ibm.mq.MQC;
import com.ibm.mq.MQEnvironment;
import com.ibm.mq.MQGetMessageOptions;
import com.ibm.mq.MQMessage;
import com.ibm.mq.MQPutMessageOptions;
import com.ibm.mq.MQQueue;
import com.ibm.mq.MQQueueManager;

/**
 * 测试调用MQ
 *
 * @author Administrator
 *
 */
public class TestMQ {

	/**
	 * 队列管理器
	 */
	private static final String MQ_QUEUE_MANAGER = "QueueManager";

	/**
	 * 队列
	 */
	private static final String MQ_QUEUE = "XML.IN";

	/**
	 * 通道
	 */
	private static final String MQ_CHANNEL = "SYSTEM.ADMIN.SVRCONN";

	/**
	 * IP
	 */
	private static final String MQ_HOST = "localhost";

	/**
	 * 端口
	 */
	private static final int MQ_PORT = 1414;

	private MQQueueManager qMgr;

	/**
	 * 测试
	 * @param args
	 */
	public static void main(String[] args) {
		TestMQ test = new TestMQ();
		test.getConnMQManager();
		test.sendMessage("1111111");
		test.receiveMsg();
	}

	/**
	 * 发送消息到MQ
	 * @param message
	 */
	public void sendMessage(String message) {
		MQQueue mqQueue = null;
		try {
			// 建立连接
			int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT| MQC.MQOO_INQUIRE;
			mqQueue = qMgr.accessQueue(MQ_QUEUE, openOptions, null, null, null);
			MQMessage msg = new MQMessage();
			msg.format = MQC.MQFMT_STRING;
			msg.characterSet = 1381;
			msg.writeObject(message);
			MQPutMessageOptions pmo = new MQPutMessageOptions();
			// 设置消息用不过期
			msg.expiry = -1;
			// 将消息放入队列
			mqQueue.put(msg, pmo);
		} catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
		} finally{
			if(mqQueue!=null){
				try {
					mqQueue.close();
				} catch (Exception e2) {
					// TODO: handle exception
					e2.printStackTrace();
				}
			}
		}
	}

	/**
	 * 读取MQ消息
	 */
	public void receiveMsg(){
		MQQueue mqQueue = null;
		try {
			// 建立连接
			int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT| MQC.MQOO_INQUIRE;
			mqQueue = qMgr.accessQueue(MQ_QUEUE, openOptions, null, null, null);
			// 队列深度
			int depth = mqQueue.getCurrentDepth();
			System.out.println("当前队列深度为:"+depth);
			while (depth-->0){
				// 要读取的消息
				MQMessage msg = new MQMessage();
				MQGetMessageOptions mqGet = new MQGetMessageOptions();
				mqQueue.get(msg, mqGet);
				System.out.println("消息的大小为:"+msg.getDataLength());
				System.out.println("消息的内容为:"+msg.readObject());
			}
		} catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
		} finally{
			if(mqQueue!=null){
				try {
					mqQueue.close();
				} catch (Exception e2) {
					// TODO: handle exception
					e2.printStackTrace();
				}
			}
		}
	}

	/**
	 * 获取连接
	 */
	public void getConnMQManager() {
		MQEnvironment.hostname = MQ_HOST;
		MQEnvironment.channel = MQ_CHANNEL;
		MQEnvironment.CCSID = 1381; // 字符编码
		MQEnvironment.port = MQ_PORT;
		try {
			qMgr = new MQQueueManager(MQ_QUEUE_MANAGER);
		} catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
		}
	}

	/**
	 * 关闭连接
	 */
	public void closeConnMQManager() {
		if (qMgr != null) {
			try {
				qMgr.close();
			} catch (Exception e) {
				// TODO: handle exception
				e.printStackTrace();
			}
		}
	}
}

对于报以下错误的可参考http://www-01.ibm.com/support/docview.wss?uid=swg21636532

MQJE001:发生 MQException:完成码 2,原因 2035

MQJE036:队列管理器拒绝连接尝试

MQJE001:完成码 2,原因 2035

com.ibm.mq.MQException: MQJE001:完成码 2,原因 2035

时间: 2024-11-13 16:14:46

JAVA 调用MQ的相关文章

Java调用MQ队列

IBM MQ 6.0中设置两个队列,(远程队列.通道之类都不设置). 队列管理器是XIR_QM_1502 队列名称是ESBREQ IP地址是10.23.117.134(远程的一台电脑,跟我的电脑不在一个局域网内) 端口1414 CCSID 1208 MQ配置可以参考这个,有配图http://wenku.baidu.com/view/06d108d0360cba1aa811daa3.html 程序如下,发送线程两个,接收线程一个.接收完毕后就结束. [java] view plaincopy /*

Java调用WebService 接口 实例

这里给大家介绍一下,Java调用webservice的一个实例的过程. 本项目不能运行,因为接口地址不可用. 这里只是给大家介绍一个过程,同时留作自己的笔记.如果要学习,可以参照别人的实例.比较好. ①选择项目根目录的src ,右键,new --> webservice client 然后输入地址: http://172.18.100.52:456/hello?wsdl 必须要加wsdl结尾,这样才是一个webservice的接口. finlish.这时候刷新项目.可以看到项目下/src/com

java 调用 keytool 生成keystore 和 cer 证书

keytool是一个Java数据证书的管理工具, keytool将密钥(key)和证书(certificates)存在一个称为keystore的文件中在keystore里, 包含两种数据: 密钥实体(Key entity)——密钥(secret key)又或者是私钥和配对公钥(采用非对称加密) 可信任的证书实体(trusted certificate entries)——只包含公钥 ailas(别名)每个keystore都关联这一个独一无二的alias,这个alias通常不区分大小写 下面给出一

java调用phantomjs采集ajax加载生成的网页

java调用phantomjs采集ajax加载生成的网页 日前有采集需求,当我把所有的对应页面的链接都拿到手,准备开始根据链接去采集(写爬虫爬取)对应的终端页的时候,发觉用程序获取到的数据根本没有对应的内容,可是我的浏览器看到的内容明明是有的,于是浏览器查看源代码也发觉没有,此时想起该网页应该是ajax加载的.不知道ajax的小朋友可以去学下web开发啦. 采集ajax生成的内容手段不外乎两种.一种是通过http观察加载页面时候的请求,然后我们模仿该请求去得到对应的内容,第二种则是模仿浏览器行为

Java调用Linux命令(cd的处理)

一.Java调用Linux系统的命令非常简单 这是一个非常常用的调用方法示例: 1 public String executeLinuxCmd(String cmd) { 2 System.out.println("got cmd job : " + cmd); 3 Runtime run = Runtime.getRuntime(); 4 try { 5 Process process = run.exec(cmd); 6 InputStream in = process.getIn

JAVA调用Shell脚本

在实际项目中,Java有时候需要调用C写出来的东西,除了JNI以外,我认为一种比较好的方法是JAVA调用Shell.先把C写出来的make成可执行文件,然后再写一个shell脚本执行该可执行文件,最后是JAVA调用该shell脚本. JAVA调用很简单,例子如下: 首先是shell脚本 [plain] view plain copy print? #!/bin/sh echo Begin word cluster /home/felven/word2vec/word2vec -train /ho

ndk学习17: jni之Java调用C&C++

一.Hello World 1. 定义函数原型 native关键字定义的函数即为jni函数 2.生成头文件 切换到src目录执行: (这个过程可以写脚本自动完成,比如自动拷贝到jni目录) javah -jni 包名.类名 在根目录下生成: org_bing_testjni_MainActivity.h 3. 工程中添加jni代码 工程右键->添加native code->输入名字->finish 多了如下文 新建一个Application.mk,配置相关选项(详细查看ndk有关Appl

java调用c++ dll出现中文乱码

最近的开发用到了使用java调用本机动态连接库的功能,将文件路径通过java调用C++代码对文件进行操作.在调用中如果路径中包含有中文字符就会出现问题,程序运行就会中止.下面用一个小例子,来说明记录下解决的方法. java中传入一个字符串,调用c++代码将字符串输出 public class CommonUtil { static { System.loadLibrary("nativeTest"); } public native static void Print(String s

JAVA调用C语言写的SO文件

JAVA调用C语言写的SO文件 因为工作需要写一份SO文件,作为手机硬件IC读卡和APK交互的桥梁,也就是中间件,看了网上有说到JNI接口技术实现,这里转载了一个实例 1 // 用JNI实现 2 // 实例: 3 4 // 创建HelloWorld.java 5 class HelloWorld 6 { 7 private native void print(); 8 public static void main(String[] args) 9 { 10 new HelloWorld().p