JAVA从MQ读取消息的时候报错及解决
来源:互联网 发布:怎么查淘宝卖家的地址 编辑:程序博客网 时间:2024/05/22 04:28
网上有一个例子 ,是JAVA将消息写入到MQ,再通过JAVA去读取消息,采用MQMessage读消息的方法readUTF()去读取的时候,如下
package com.base;
import java.io.IOException;
import com.ibm.mq.MQC;
import com.ibm.mq.MQEnvironment;
import com.ibm.mq.MQException;
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;
public class testMQ1{
//定义队列管理器和队列的名称
private static String qmName;
private static String qName;
private static MQQueueManager qMgr;
static{
//设置环境:
//MQEnvironment中包含控制MQQueueManager对象中的环境的构成的静态变量,MQEnvironment的值的设定会在MQQueueManager的构造函数加载的时候起作用,
//因此必须在建立MQQueueManager对象之前设定MQEnvironment中的值.
MQEnvironment.hostname="10.10.3.234"; //MQ服务器的IP地址
MQEnvironment.channel="KTMAPS01"; //服务器连接的通道
// MQEnvironment.CCSID=1386; //服务器MQ服务使用的编码1381代表GBK、1208代表UTF(Coded Character Set Identifier:CCSID)
MQEnvironment.port=60002; //MQ端口
qmName = "KTMAPS01"; //MQ的队列管理器名称
qName = "EOCELGRR.ERP"; //MQ远程队列的名称
try {
//定义并初始化队列管理器对象并连接
//MQQueueManager可以被多线程共享,但是从MQ获取信息的时候是同步的,任何时候只有一个线程可以和MQ通信。
qMgr = new MQQueueManager(qmName);
} catch (MQException e) {
// TODO Auto-generated catch block
System.out.println("初使化MQ出错");
e.printStackTrace();
}
}
/**
* 往MQ发送消息
* @param message
* @return
*/
public static int sendMessage(String message){
int result=0;
try{
//设置将要连接的队列属性
// Note. The MQC interface defines all the constants used by the WebSphere MQ Java programming interface
//(except for completion code constants and error code constants).
//MQOO_INPUT_AS_Q_DEF:Open the queue to get messages using the queue-defined default.
//MQOO_OUTPUT:Open the queue to put messages.
/*目标为远程队列,所有这里不可以用MQOO_INPUT_AS_Q_DEF属性*/
//int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT;
/*以下选项可适合远程队列与本地队列*/
int openOptions = MQC.MQOO_OUTPUT | MQC.MQOO_FAIL_IF_QUIESCING;
//连接队列
//MQQueue provides inquire, set, put and get operations for WebSphere MQ queues.
//The inquire and set capabilities are inherited from MQManagedObject.
/*关闭了就重新打开*/
if(qMgr==null || !qMgr.isConnected()){
qMgr = new MQQueueManager(qmName);
}
MQQueue queue = qMgr.accessQueue(qName, openOptions);
//定义一个简单的消息
MQMessage putMessage = new MQMessage();
//将数据放入消息缓冲区
putMessage.writeUTF(message);
//设置写入消息的属性(默认属性)
MQPutMessageOptions pmo = new MQPutMessageOptions();
//将消息写入队列
queue.put(putMessage,pmo);
queue.close();
}catch (MQException ex) {
System.out.println("A WebSphere MQ error occurred : Completion code "
+ ex.completionCode + " Reason code " + ex.reasonCode);
ex.printStackTrace();
}catch (IOException ex) {
System.out.println("An error occurred whilst writing to the message buffer: " + ex);
}catch(Exception ex){
ex.printStackTrace();
}finally{
try {
qMgr.disconnect();
} catch (MQException e) {
e.printStackTrace();
}
}
return result;
}
/**
* 从队列中去获取消息,如果队列中没有消息,就会发生异常,不过没有关系,有TRY...CATCH,如果是第三方程序调用方法,如果无返回则说明无消息
* 第三方可以将该方法放于一个无限循环的while(true){...}之中,不需要设置等待,因为在该方法内部在没有消息的时候会自动等待。
* @return
*/
public static String getMessage(){
String message=null;
try{
//设置将要连接的队列属性
// Note. The MQC interface defines all the constants used by the WebSphere MQ Java programming interface
//(except for completion code constants and error code constants).
//MQOO_INPUT_AS_Q_DEF:Open the queue to get messages using the queue-defined default.
//MQOO_OUTPUT:Open the queue to put messages.
int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_OUTPUT;
MQMessage retrieve = new MQMessage();
//设置取出消息的属性(默认属性)
//Set the put message options.(设置放置消息选项)
MQGetMessageOptions gmo = new MQGetMessageOptions();
gmo.options = gmo.options + MQC.MQGMO_SYNCPOINT;//Get messages under sync point control(在同步点控制下获取消息)
gmo.options = gmo.options + MQC.MQGMO_WAIT; // Wait if no messages on the Queue(如果在队列上没有消息则等待)
gmo.options = gmo.options + MQC.MQGMO_FAIL_IF_QUIESCING;// Fail if Qeue Manager Quiescing(如果队列管理器停顿则失败)
gmo.waitInterval = 10000 ; // Sets the time limit for the wait.(设置等待的毫秒时间限制)
/*关闭了就重新打开*/
if(qMgr==null || !qMgr.isConnected()){
qMgr = new MQQueueManager(qmName);
}
MQQueue queue = qMgr.accessQueue(qName, openOptions);
// 从队列中取出消息
queue.get(retrieve, gmo);
message = retrieve.readUTF();
System.out.println("The message is: " + message);
queue.close();
}catch (MQException ex) {
System.out.println("A WebSphere MQ error occurred : Completion code "
+ ex.completionCode + " Reason code " + ex.reasonCode);
}catch (IOException ex) {
System.out.println("An error occurred whilst writing to the message buffer: " + ex);
}catch(Exception ex){
ex.printStackTrace();
}finally{
try {
qMgr.disconnect();
} catch (MQException e) {
e.printStackTrace();
}
}
return message;
}
public static void main(String args[]) {
/*下面两个方法可同时使用,也可以单独使用*/
// sendMessage("this is a test");
getMessage();
}
}
JAVA通过writeUTF将消息写入到MQ,再通过JAVA采用MQMessage读消息的方法readUTF()去读取的时候,就不会报错,可以正常读出来。但是如果采用在MQ资源管理器中插入测试消息或者是通过另外一台MQ服务器往当前MQ服务器通过远程队例写消息过来,通过JAVA读取出会错.
我用的时候一样碰到了这样的问题
于是找了号称是解决方法的方法
...
MQMessage retrieve = new MQMessage();
String message=retrieve.readStringOfCharLength(32000).trim();
...
结果我自己用的时候
int dataLength = retrieve.getDataLength();
retrieve.readStringOfCharLength(dataLength); 报红怎么,换了websphere6.1的包后还是红
无奈..只能另辟蹊径:
...
byte[] rawData = new byte[retrieve.getMessageLength()]; //先转byte
retrieve.readFully(rawData); //读出所有数据
String msg = new String(rawData); //byte转string
....
整个xml数据才算是取出
- 通过JAVA从MQ读取消息的时候报错及解决
- JAVA从MQ读取消息的时候报错及解决
- 通过JAVA从MQ读取消息的时候报错及解决
- mq的链接 消息读取与存放
- 【消息队列MQ】从MQ种类说起
- 【消息队列MQ】从MQ种类说起
- IBM Websphere MQ _02 MQ消息队列、通道、消息的创建及传输
- mq的消息调用
- xcode7发送session请求的时候报错解决
- 解决butterknife添加依赖的时候报错
- 消息队列mq的原理及实现方法
- 消息队列mq的原理及实现方法
- 使用sqoop从Oracle或mysql抽取数据到HDFS遇到的报错及解决
- java读取过大的excel表的时候报内存溢出的错误的解决办法
- 理解JAVA MQ消息中间件
- 更新插件的时候报错,及解决方法
- Active MQ延时发送消息的Java示例代码段
- Active MQ延时发送消息的Java示例代码段
- 再次换人搬家
- Josephus问题
- 关于flex读取本地文件的问题
- Eclipse默认工作空间修改
- 使用Aspect中的annotation标签的方法来截获所有的Exception,进行控制台打印
- JAVA从MQ读取消息的时候报错及解决
- 程序语言性能比拼
- ERwin Data Modeler 建模实践
- 面向对象的三个基本特征
- libevent源码深度剖析八
- ORA-04092: cannot COMMIT in a trigger
- MERGE JOIN CARTESIAN
- 关于gets的问题
- 超强:Unix道德经(英文版)