本文主要通过两台机器,搭建MQ消息传输的环境,并编写测试程序进行测试。
第一、准备工作
准备2台Win2000环境(XP也可),通过以太网连通。
机器A:代码为00000000,IP地址为:10.1.1.1
机器B:代码为88888888,IP地址为:10.1.1.2
安装MQ 5.3
第二、创建MQ对象
A机器上:
1、打开“WebSphere MQ资源管理器”,新建队列管理器,名称为QM_00000000,其余采用默认设置;
2、在QM_00000000队列管理器中创建本地队列,名称为LQ_00000000;
3、创建传输队列,名称为XQ_88888888(新建时选择“本地队列”,将“用法”设置为“传输”);
4、创建远程队列定义,名称为RQ_88888888,指定远程队列名称为LQ_88888888,远程队列管理器名称为QM_88888888,传输队列名称为XQ_88888888;
5、创建发送方通道,名称为00000000.88888888,传输协议为TCP/IP,连接名称为10.1.1.2(1414),传输队列为XQ_88888888;
6、创建接受方通道,名称为88888888.00000000,采用默认设置;
7、创建服务器连接通道,名称为DC.SVRCONN,采用默认设置(该通道主要给后面的测试程序使用)。
B机器和A机器上的操作一样,只是命名不同,如下:
1、打开“WebSphere MQ资源管理器”,新建队列管理器,名称为QM_88888888,其余采用默认设置;
2、在QM_88888888队列管理器中创建本地队列,名称为LQ_88888888;
3、创建传输队列,名称为XQ_00000000(新建时选择“本地队列”,将“用法”设置为“传输”);
4、创建远程队列定义,名称为RQ_00000000,指定远程队列名称为LQ_00000000,远程队列管理器名称为QM_00000000,传输队列名称为XQ_00000000;
5、创建发送方通道,名称为88888888.00000000,传输协议为TCP/IP,连接名称为10.1.1.1(1414),传输队列为XQ_00000000;
6、创建接受方通道,名称为00000000.88888888,采用默认设置;
7、创建服务器连接通道,名称为DC.SVRCONN,采用默认设置。
第三、消息测试
在A、B机器上分别启动其发送方通道,正常情况通道状态应为“正在运行”。
通过如下测试程序进行测试,文件名为:MQTest.java,在机器A上进行运行(如在B上运行请读者自行适当修改)。
import java.io.IOException;
import java.util.Hashtable;
import com.ibm.mq.MQException;
import com.ibm.mq.MQMessage;
import com.ibm.mq.MQPutMessageOptions;
import com.ibm.mq.MQQueue;
import com.ibm.mq.MQQueueManager;
public class MQSample{
//定义队列管理器和队列的名称
private static String qmName = "QM_00000000";
private static String qName = "RQ_88888888";
private static MQQueueManager qMgr;
private static Hashtable properties = new Hashtable();
public static void main(String args[]) {
try {
properties.put("hostname", "10.1.1.1");
properties.put("port", new Integer(1414));
properties.put("channel", "DC.SVRCONN");
properties.put("CCSID", new Integer(1381));
properties.put("transport","MQSeries");
// Create a connection to the queue manager
qMgr = new MQQueueManager(qmName,properties);
// Set up the options on the queue we wish to open...
int openOptions = 16;
// Now specify the queue that we wish to open,
// and the open options...
MQQueue remoteQ = qMgr.accessQueue(qName, openOptions);
// Define a simple WebSphere MQ message, and write some text in UTF format..
MQMessage putMessage = new MQMessage();
putMessage.writeUTF("Test");
// specify the message options...
MQPutMessageOptions pmo = new MQPutMessageOptions();
// accept the defaults, same as MQPMO_DEFAULT
// put the message on the queue
remoteQ.put(putMessage,pmo);
System.out.println("Message has been input into the Remote Queue");
// Close the queue...
remoteQ.close();
// Disconnect from the queue manager
qMgr.disconnect();
}catch (MQException ex) {
// If an error has occurred in the above, try to identify what went wrong
// Was it a WebSphere MQ error?
System.out.println("A WebSphere MQ error occurred : Completion code " + ex.completionCode +
" Reason code " + ex.reasonCode);
}catch (IOException ex) {
// Was it a Java buffer space error?
System.out.println("An error occurred whilst writing to the message buffer: " + ex);
}catch(Exception ex){
ex.printStackTrace();
}
}
}
分享到:
相关推荐
本教程将重点讨论如何在Java中实现与MQ的接口交互。 首先,理解MQ的基本概念是至关重要的。MQ允许应用程序通过发布和订阅消息进行通信,这些消息在生产者和消费者之间传递,而不需要两者之间有直接的连接。MQ提供了...
* 消息队列系统:使用Websphere MQ来实现消息队列系统,管理和处理大量的消息 Websphere MQ的Java API Websphere MQ提供了一个Java API,允许开发者使用Java语言来开发Websphere MQ的应用程序。该API提供了许多...
IBM MQ是一个消息代理软件,它允许应用程序通过网络发送和接收消息。它是中间件的一种形式,主要用于开发和集成应用程序,提供可靠的消息传递,并支持跨多个平台的数据传输。IBM MQ支持多种编程语言和平台,使开发...
后续章节会详细介绍WebSphere MQ的安装与配置、消息队列管理、C++和Java编程接口的使用,以及实际应用场景示例,帮助读者全面掌握WebSphere MQ的使用。 通过学习本教程,读者将能够熟练地在项目中运用WebSphere MQ...
7. 发送与接收消息:掌握编写程序来发送和接收消息的方法,使用API(如Java的JMS接口或C的MQSeries API)。 8. 配置通道:了解通道的作用,学习设置传输通道、服务器通道,进行SSL加密和认证配置。 四、高级特性 ...
点对点模式则通过队列实现,消息被发送到队列,一个或多个接收者可以从队列中获取消息。 2. **WebSphere MQ组件**: - **队列管理器**:是MQ的核心,负责管理队列、通道和其他资源。 - **队列**:用于存储消息,...
- **选择功能部件**:在功能部件页面中,选择要安装的功能,如服务器、MQ Explorer、Java 和 .Net 消息传递与 WebService,然后点击“下一步”开始安装过程。 - **WebSphere MQ网络配置**:在WebSphere MQ网络配置...
WebSphere MQ支持多种编程语言的API,包括Java、C、C++、Python等,使得开发人员可以轻松地将消息功能集成到自己的应用程序中。 ## 10. 应用场景 WebSphere MQ广泛应用于金融交易、物流跟踪、物联网设备通信等领域...
Websphere MQ 是一款强大的中间件,用于在企业系统中实现可靠、高效的消息传递。它提供了统一的接口,使得不同的应用程序和服务能够通过消息队列进行通信,而不必直接依赖于对方的时间限制或运行状态。本教程将深入...
4. **Java编程接口(JMS)**:了解Java Message Service(JMS)API,它是Java开发人员与MQ交互的标准方式,学习发送和接收消息的代码示例。 5. **MQ编程模式**:探索各种MQ编程模式,如同步和异步消息处理,以及...
XXL-MQ是一款专为Java开发设计的轻量级分布式消息队列系统,它提供了高效、稳定的消息传递功能,能够帮助开发者在分布式环境下构建可靠的数据通信。作为一款强大的中间件,XXL-MQ旨在解决微服务架构中的异步处理、...
WebSphere MQ提供了丰富的API和编程指南,支持多种编程语言,如C++和Java,帮助开发者创建能与MQ交互的应用程序。开发过程中,理解消息模型、队列操作和安全机制是至关重要的。 **学习资源** 为了深入学习WebSphere...
在IT行业中,Java消息...通过以上步骤,你可以使用JMS客户端模式在远程IBM MQ服务器上实现消息的同步和异步收发。这种模式使得应用程序能够解耦,提高可扩展性和可靠性,同时允许在分布式环境中有效地处理大量数据。
教程会讲解如何设置和配置消息队列接口(MQI),这是应用与WebSphere MQ交互的主要途径。 其次,WebSphere MQ的架构主要包括Queue Manager(队列管理器)、Queues(队列)和Channels(通道)。Queue Manager是管理...
- **Java API**:适用于Java开发者,提供了丰富的接口来实现消息的发送和接收。 - **C/C++ API**:适用于C/C++开发者,提供了底层控制和高级功能的支持。 - **其他语言支持**:除了Java和C/C++之外,MQ还支持.NET...
【MQ配置与测试详解】 在IT领域,消息队列(Message Queuing,简称MQ)是一种高效的数据通信机制,常用于分布式系统中不同组件之间的异步通信。本文将深入讲解WebSphere MQ的配置与测试,包括如何在两台机器之间...
在Java中使用IBM MQ,我们需要引入IBM的MQ Java API,这个API提供了连接、发送、接收消息等操作的接口。以下是一些关键知识点: 1. **连接管理**:首先,我们需要创建一个`MQQueueManager`对象来连接到MQ服务器。这...
总的来说,Java消息队列的使用涉及多个层面,包括选择合适的MQ实现、理解JMS接口和消息模型、配置连接和会话、处理异常以及在特定场景下利用阻塞队列优化性能。通过深入学习这些知识点,开发者可以有效地利用消息...