程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> WebSphere MQ傳輸環境搭建和測試

WebSphere MQ傳輸環境搭建和測試

編輯:關於JAVA

在“WebSphere MQ程序設計初探”一文中,討論了從MQ隊列管理器的本地隊列中放置和讀出消息的程序,本文主要通過兩台機器,搭建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();

}

}

}

-------------------------------------------------------------------------------------------

運行程序後,請在B機器的本地隊列LQ_88888888中檢查是否有消息存在,如果有說明測試成功。

讀者可以自行編寫把消息從對方的本地隊列讀取出來的程序。

如果讀者對以上的內容有任何疑問,可以和我聯系,[email protected]

版權所有,嚴禁轉載

參考資料:

1、《WebSphere MQ System Administration Guide》Third edition (May 2004),SC34-6068-02

2、《WebSphere MQ Using Java》Third edition (January 2004),SC34-6066-02

附件:MQTest.Java(2K)

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved