MQ消息队列的简称是一种应用程序对应用程序的通信方法。说白了也就是通过队列的方式来对应用程序进行数据通信。而无需专用链接来链接它们。
MQ的通讯方式
1.数据报的方式 Datagram (Send and forget)
应用程序在创建完消息后。利用MQ的API将消息发送到队列中。它充分利用了MQ(once and once only )
2.请求和应答方式 Request/Reply
发送消息之后需等待对方处理结果。 需考虑如下问题:
a.等待应答的时间是多少?
b.如果没有应答怎么办。
c.本次session是否需要保留?
MQ的开发流程
1.让应用程序与队列管理器链接,通过MQconnect调用来进行此链接。
2.使用MQOpen调用为输出打开一个队列
3.应用程序使用MQPut调用将其数据放到队列上。
4.调用MQOpen调用打开输入队列
5.使用MQGet从队列上接收数据
安装步骤。(此处为转载文章,作者已经证实所有步骤。)
服务端的安装:
Windows版服务器CD-ROM插入CD-ROM驱动器。
安装启动板"窗口为止。
- WebSphere MQ CD
- 因特网
- 网络
注意:对于定制安装,可能不需要所有的必备软件。
MQ"安装选项
(9)选择启动WebSphere
MQ安装程序,然后等待,直到显示了带有欢迎信息的"WebSphere MQ安装"窗口为止。
(10)单击"下一步"按钮继续。
(11)阅读面板上的信息和许可证条款,选择接受,然后单击"下一步"。
(12)如果机器上未安装过此产品的前一个版本,则显示"安装类型"面板。选择希望的安装类型(一般选择"典型"安装即可),然后单击"下一步"按钮。
(13)"WebSphere
MQ安装"窗口显示"安装WebSphere MQ就绪"信息。该窗口还显示用户选中的安装摘要,单击"安装"开始正式安装。
MQ后,"WebSphere MQ安装"窗口显示以下信息:安装向导成功完成。
MQ"向导。
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4ff61/4ff61ce5991d17f1983fe81961066fd0479dca9a" alt="技术分享图片"
data:image/s3,"s3://crabby-images/26e9b/26e9bbf73b42192abfabe258a702a304ec556f45" alt="技术分享图片"
data:image/s3,"s3://crabby-images/477b9/477b969a726f36140ff8d893c1b517d64d7fe132" alt="技术分享图片"
data:image/s3,"s3://crabby-images/63580/63580cb9a51f302276b8cae2ea9add5e51240fb4" alt="技术分享图片"
data:image/s3,"s3://crabby-images/05d68/05d687aa214473c900e852f0c7f5e16e9cd13cc6" alt="技术分享图片"
data:image/s3,"s3://crabby-images/400bb/400bb85f8277180d71fe1b655a5ff87f0ebe6cd9" alt="技术分享图片"
data:image/s3,"s3://crabby-images/e9783/e978386e7b9950ffbf5fe7988612c83dbc1f9049" alt="技术分享图片"
data:image/s3,"s3://crabby-images/34a95/34a95263366f7f4326cd04fc3ae1b77c77e9bb66" alt="技术分享图片"
data:image/s3,"s3://crabby-images/f525d/f525d32c73fd802d3aa08bf8b88b33cb00f5d2d5" alt="技术分享图片"
data:image/s3,"s3://crabby-images/47a89/47a8964c25f2a07ef3a3d4e30e846911d0d3944a" alt="技术分享图片"
data:image/s3,"s3://crabby-images/d0272/d02723f05e0bbcaa4053c8cf0c8893d21bc91451" alt="技术分享图片"
data:image/s3,"s3://crabby-images/fc137/fc1371c02766b79761c865292eb40a3de68fc377" alt="技术分享图片"
data:image/s3,"s3://crabby-images/131c2/131c26b2d22b094a7ab493dbd0f834f550f779a5" alt="技术分享图片"
data:image/s3,"s3://crabby-images/92526/925268864901774008b5008b924254e4602508be" alt="技术分享图片"
data:image/s3,"s3://crabby-images/456c5/456c5f54c1586d88144b08822308384811ad1945" alt="技术分享图片"
data:image/s3,"s3://crabby-images/c7d24/c7d24d3a1ea9953eb1052395bfc2080259e15bd8" alt="技术分享图片"
data:image/s3,"s3://crabby-images/348f5/348f57591f88676949c82aeab6d4cd83191e832f" alt="技术分享图片"
且包含JAVA实现的客户端程序。由此构成一个完整的客户端-服务器的流程。
服务端配置
WebSphere MQ"->"WebSphere MQ 资源管理器",进入WebSphere MQ
资源管理器界面。如下图所示:
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
服务端配置
data:image/s3,"s3://crabby-images/094f1/094f1da3806ef466563a82b87ed1693a47798861" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/b3654/b36543d3f024e5e728fc7d3db2bee835464dcaf1" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/f9f1e/f9f1e8f1a787d15bfcc2d438d5355009070623c6" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
设置队列日志
data:image/s3,"s3://crabby-images/4b321/4b321f4ce4f1279175cf0c8cb70f4a6b90ca7234" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/6bb7b/6bb7b8b7e771a87bd95dd57155bfa0743636e26c" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
设置队列管理器QM_JACK的侦听端口
data:image/s3,"s3://crabby-images/7570a/7570a981124969eb909496e7104d8e8b6e515a1a" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
系统等待界面
data:image/s3,"s3://crabby-images/48a86/48a861c843fb81fe31cab52ebb30a9904ec71b98" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
系统队列管理器QM_JACK创建成功
data:image/s3,"s3://crabby-images/52e7e/52e7eafa6953e7796c7345c9392d2badd7e77729" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/19399/19399f252c908627d3c3e41c98a5fa6c99440daa" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/7c264/7c264c6d639ac8b064b7c812be0bbfab814ce7df" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
创建服务器连接通道
data:image/s3,"s3://crabby-images/42901/429017a97cedfda0be5bdf170dba5e56ef5764ef" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/f3474/f3474bbd9a1e4decee57022768b23d967f65b576" alt="技术分享图片"
Linux下的root用户使用,那么,我们就需要在MQ的服务端(也就是Windows
xp系统中添加名为"root"的用户)所在的计算机系统中添加名为"root"的用户。具体步骤如下:
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
创建系统用户
data:image/s3,"s3://crabby-images/78edd/78eddd7175a545c028203efbc9aeb119a23480b0" alt="技术分享图片"
图22 创建系统用户
Server后系统自动创建的)。具体操作如下:
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
设置系统用户所在组
data:image/s3,"s3://crabby-images/36821/3682166808d9858cf5c59a7b88d0206008068e1c" alt="技术分享图片"
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/b2a6d/b2a6d02b754bef9856bdd38b58e97e32b814d92e" alt="技术分享图片"
图25
设置系统用户所在组
data:image/s3,"s3://crabby-images/4f804/4f804655546945506d433072575ba512eebb8f62" alt="技术分享图片"
data:image/s3,"s3://crabby-images/05db1/05db1b29e72d259fac3a4030839e276a6469e242" alt="技术分享图片"
图27 设置系统用户所在组
import java.io.File; import java.io.FileInputStream; import java.io.InputStream; import java.util.Properties; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; 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.MQQueue; import com.ibm.mq.MQQueueManager; /** * 函数功能: MQjava客户端实现 */ public class MQClient { /** * Logger for this class */ private static final Log logger = LogFactory.getLog(MQClient.class); private String strExtraSendXmlFileName = "D:\\jndi.properties"; private static Properties props; static { props = new Properties(); props.put("mqHostName", "139.31.89.67"); props.put("mqPort", "4032"); props.put("mqCCSID", "1381"); props.put("mqUserName", "liujx"); props.put("mqPassword", "linux"); props.put("mqQManager", "Monitor_Queue_Manager"); props.put("mqChannel", "Monitor_Conn_Chanel"); props.put("mqLocalOutQueue", "Q_RECEIVE"); props.put("mqLocalInQueue", "Q_RECEIVE"); } /** * * 函数功能:TODO 主测试方法 <br> * 相关参数: <br> * * @param args * 修改记录: <br> */ public static void main(String[] args) { MQClient test = new MQClient(); // 发送消息 test.putMsg(); // 接收消息 test.getMsg(); } public void putMsg() { // MQ发送数据 try { // 建立MQ客户端应用上下文环境 MQEnvironment.hostname = props.getProperty("mqHostName"); MQEnvironment.port = Integer.parseInt(props.getProperty("mqPort")); MQEnvironment.CCSID = Integer .parseInt(props.getProperty("mqCCSID")); MQEnvironment.channel = props.getProperty("mqChannel"); MQEnvironment.userID = props.getProperty("mqUserName"); MQEnvironment.password = props.getProperty("mqPassword"); // 连接队列管理器 MQQueueManager qMgr = new MQQueueManager( props.getProperty("mqQManager")); int openOptions = MQC.MQOO_OUTPUT | MQC.MQOO_FAIL_IF_QUIESCING; // 打开队列 MQQueue q = null; try { q = qMgr.accessQueue(props.getProperty("mqLocalOutQueue"), openOptions); } catch (MQException me) { System.out.println("打开队列出现通讯异常" + me.getMessage() + "\n"); return; } InputStream fins = new FileInputStream(new File( strExtraSendXmlFileName)); byte[] data = new byte[fins.available()]; fins.read(data); fins.close(); MQMessage msg = new MQMessage(); msg.write(data); // 放入消息 q.put(msg); System.out.println("客户端发送数据包成功.."); // 关闭队列 q.close(); // 断开队列管理器连接 qMgr.disconnect(); } catch (MQException e) { if (logger.isDebugEnabled()) logger.debug(e.getMessage()); e.printStackTrace(); } catch (Exception e) { if (logger.isDebugEnabled()) logger.debug(e.getMessage()); e.printStackTrace(); } } /** * * 函数功能:TODO 获取数据 <br> * 修改记录: <br> */ public void getMsg() { // MQ接收数据 try { // 建立用上下文环境 MQEnvironment.hostname = props.getProperty("mqHostName"); MQEnvironment.port = Integer.parseInt(props.getProperty("mqPort")); MQEnvironment.CCSID = Integer .parseInt(props.getProperty("mqCCSID")); MQEnvironment.channel = props.getProperty("mqChannel"); MQEnvironment.userID = props.getProperty("mqUserName"); MQEnvironment.password = props.getProperty("mqPassword"); // 建立队列管理器 MQQueueManager qMgr = new MQQueueManager( props.getProperty("mqQManager")); int openOptions = MQC.MQOO_INPUT_AS_Q_DEF | MQC.MQOO_FAIL_IF_QUIESCING; // 打开队列 MQQueue q = qMgr.accessQueue(props.getProperty("mqLocalInQueue"), openOptions); MQGetMessageOptions mgo = new MQGetMessageOptions(); mgo.options |= MQC.MQGMO_NO_WAIT; // 构造返回消息 MQMessage msg = new MQMessage(); if ((msg = fetchOneMsg(q)) != null) { byte[] xmlData = new byte[msg.getDataLength()]; msg.readFully(xmlData); logger.info(new String(xmlData)); System.out.println("接收服务器端返回数据包成功..\n接收数据为:\n" + new String(xmlData)); } // 关闭队列 q.close(); // 断开队列管理器 qMgr.disconnect(); } catch (MQException e) { logger.error(e); e.printStackTrace(); } catch (Exception e) { logger.error(e); e.printStackTrace(); } } /** * * 函数功能:TODO 从队列中取出消息 <br> * 相关参数: <br> * * @param q * @return * @throws Exception * 修改记录: <br> */ private static MQMessage fetchOneMsg(MQQueue q) throws Exception { MQGetMessageOptions mgo = new MQGetMessageOptions(); mgo.options |= MQC.MQGMO_NO_WAIT; MQMessage msg = new MQMessage(); try { // 获取消息 q.get(msg, mgo); } catch (MQException e) { return null; } return msg; } }