网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > JAVA > J2EE > J2ee核心 > 介绍关于IBM MQSeries的使用指南  

介绍关于IBM MQSeries的使用指南

2005-08-19  作者:BitsCN整理  来源:中国网管联盟  点评 投稿 收藏


  随着计算机网络和分布式应用的不断发展,远程消息传递越来越成为应用系统中不可缺少的组成部分。商业消息中间件的出现保证了消息传输的可靠性,高效率和安全性,同时也减少了系统的开发周期。目前应用最多的消息中间件产品为IBM MQSeries。本文就针对MQ的基本操作与配置进行详细的阐述,希望对读者有所帮助。
  
  一.MQ基本操作
  
  MQ中有几个很重要的组件:队列管理器(QueueManager)、队列(Queue)和通道(Channel)。其基本的操作方法如下:
  
  创建队列管理器
  crtmqm ?q QMgrName
  -q是指创建缺省的队列管理器
  
  删除队列管理器
  dltmqm QmgrName
  
  启动队列管理器
  strmqm QmgrName
  如果是启动默认的队列管理器,可以不带其名字
  
  停止队列管理器
  endmqm QmgrName 受控停止
  
  endmqm ?i QmgrName 立即停止
  
  endmqm ?p QmgrName 强制停止
  
  显示队列管理器
  dspmq ?m QmgrName
  
  运行MQSeries命令
  runmqsc QmgrName
  如果是默认队列管理器,可以不带其名字
  
  往队列中放消息
网管下载dl.bitscn.com

  amqsput QName QmgrName
  如果队列是默认队列管理器中的队列,可以不带其队列管理器的名字
  
  从队列中取出消息
  amqsget QName QmgrName
  如果队列是默认队列管理器中的队列,可以不带其队列管理器的名字
  
  启动通道
  runmqchl ?c ChlName ?m QmgrName
  
  启动侦听
  runmqlsr ?t TYPE ?p PORT ?m QMgrName
  
  停止侦听
  endmqlsr -m QmgrName
  
  MQSeries命令
  
  定义死信队列
  DEFINE QLOCAL(QNAME) DEFPSIST(YES) REPLACE
  
  设定队列管理器的死信队列
  ALTER QMGR DEADQ(QNAME)
  
  定义本地队列
  DEFINE QL(QNAME) REPLACE
  
  定义别名队列
  DEFINE QALIAS(QALIASNAME) TARGQ(QNAME)
  
  远程队列定义
  DEFINE QREMOTE(QRNAME) +
  RNAME(AAA) RQMNAME(QMGRNAME) +
  XMITQ(QTNAME)
  
  定义模型队列
  DEFINE QMODEL(QNAME) DEFTYPE(TEMPDYN)
  
  定义本地传输队列
  DEFINE QLOCAL(QTNAME) USAGE(XMITQ) DEFPSIST(YES) +
  INITQ(SYSTEM.CHANNEL.INITQ)+

网管联盟bitsCN_com


  PROCESS(PROCESSNAME) REPLACE
  
  创建进程定义
  DEFINE PROCESS(PRONAME) +
  DESCR(‘STRING’)+
  APPLTYPE(WINDOWSNT)+
  APPLICID(’ runmqchl -c SDR_TEST -m QM_ TEST’)
  其中APPLTYPE的值可以是:CICS、UNIX、WINDOWS、WINDOWSNT等
  
  创建发送方通道
  DEFINE CHANNEL(SDRNAME) CHLTYPE(SDR)+
  CONNAME(‘100.100.100.215(1418)’) XMITQ(QTNAME) REPLACE
  其中CHLTYPE可以是:SDR、SVR、RCVR、RQSTR、CLNTCONN、SVRCONN、CLUSSDR和CLUSRCVR。
  
  创建接收方通道
  DEFINE CHANNEL(SDR_ TEST) CHLTYPE(RCVR) REPLACE
  
  创建服务器连接通道
  DEFINE CHANNEL(SVRCONNNAME) CHLTYPE(SVRCONN) REPLACE
  
  显示队列的所有属性
  DISPLAY QUEUE(QNAME) [ALL]
  
  显示队列的所选属性
  DISPLAY QUEUE(QNAME) DESCR GET PUT
  DISPLAY QUEUE(QNAME)MAXDEPTH CURDEPTH
  
  显示队列管理器的所有属性
  DISPLAY QMGR [ALL]
  
  显示进程定义
  DISPLAY PROCESS(PRONAME)
  
网管论坛bbs_bitsCN_com

  更改属性
  ALTER QMGR DESCR(‘NEW DESCRIPTION’)
  ALTER QLOCAL(QNAME) PUT(DISABLED)
  ALTER QALIAS(QNAME) TARGQ(TARGQNAME)
  
  删除队列
  DELETE QLOCAL(QNAME)
  DELETE QREMOTE(QRNAME)
  
  清除队列中的所有消息
  CLEAR QLOCAL(QNAME)
  
  二.配置一个能够通信的远程连接
  
  以上讲述了MQ的基本命令操作,但只知道这些是没有实际意义的。MQ的最终目的是实现远程通信,所以下面就以一个具体的例子来说明如何实现远程连接。这个例子的目的是建立可以实现消息传递的一对MQ服务器,它们分别基于NT和UNIX平台。
  
  首先在NT端建一队列管理器
  crtmqm ?q QM_NT
  
  启动队列管理器
  strmqm QM_NT
  
  运行MQ控制台命令
  runmqsc QM_NT
  
  创建死信队列
  DEFINE QL(NT.DEADQ) DEFPSIST(YES) REPLACE
  
  更改队列管理器属性,设置其死信队列
  ALTER QMGR DEADQ(NT.DEADQ)
  
  创建进程定义
  DEFINE PROCESS(P_NT)+
  APPLTYPE(WINDOWSNT)+
  APPLICID(’ runmqchl -c SDR_NT -m QM_NT’)
网管下载dl.bitscn.com

  
  创建本地传输队列
  DEFINE QL(QT_NT) USAGE(XMITQ) DEFPSIST(YES) +
  INITQ(SYSTEM.CHANNEL.INITQ)+
  PROCESS(P_NT) REPLACE
  
  创建远程队列定义,对应于UNIX机器上的本地队列Q_UNIX,传输队列为QT_NT
  DEFINE QREMOTE(QR_NT)+
  RNAME(Q_UNIX) RQMNAME(QM_UNIX)+
  XMITQ(QT_NT)
  
  创建发送方通道,其传输队列为QT_NT,远程主机地址为10.10.10.2,侦听端口为1414
  DEFINE CHANNEL(SDR_NT) CHLTYPE(SDR)+
  CONNAME(‘10.10.10.2(1414)’) XMITQ(QT_NT) REPLACE
  
  创建服务器连接通道
  DEFINE CHANNEL(S_NT) CHLTYPE(SVRCONN) REPLACE
  
  在UNIX端创建队列管理器
  crtmqm ?q QM_UNIX
  
  启动队列管理器
  strmqm QM_UNIX
  
  添加侦听程序
  
  修改/etc/services文件,加入一行:
  MQSeries 1414/tcp #MQSeries channel listener
  
  修改/etc/inetd.conf文件,加入一行(启动侦听程序)
  MQSeries stream tcp nowait mqm /usr/lpp/mqm/bin/amqcrsta amqcrsta ?m QM_UNIX
  
网管网www_bitscn_com

  运行以下命令,以使修改起作用
  refresh ?s inetd
  
  运行MQ控制台命令
  runmqsc QM_UNIX
  
  创建死信队列
  DEFINE QL(UNIX.DEADQ) DEFPSIST(YES) REPLACE
  
  更改队列管理器属性,设置其死信队列
  ALTER QMGR DEADQ(UNIX.DEADQ)
  
  创建接收方通道,其名字必须与远程发送方相同
  DEFINE CHANNEL(SDR_NT) CHLTYPE(RCVR) REPLACE
  
  创建本地队列
  DEFINE QL(Q_UNIX) DEFPSIST(YES) REPLACE
  
  创建服务器连接通道
  DEFINE CHANNEL(S_UNIX) CHLTYPE(SVRCONN) REPLACE
  
  经过以上操作之后,远程连接的配置工作完成。接下来需要验证配置是否正确。
  
  在NT端启动发送方通道
  runmqchl ?c SDR_NT ?m QM_NT 或 start chl(SDR_NT)
  
  从NT端发送消息到UNIX端
  amqsput QR_NT QM_NT
  
  在UNIX端接收消息
  /usr/mqm/samp/bin/amqsget Q_UNIX QM_UNIX
  
  若能收到消息,说明配置成功。
  
  另,在NT下一般情况下在建立队列管理器时会自动建立侦听器,启动队列管理器时则会自动启动侦听程序。当然也可以手动配置侦听程序。 网管联盟bitsCN@com
  
  修改\winnt\system32\drivers\etc\services文件,在文件中加入一行:
  
  MQSeries 1414/tcp #MQSeries channel listener
  
  启动侦听程序
  runmqlsr ?t tcp ?p 1414 ?m QM_NT
  
  以上说明了怎样建立简单的单向传输网络。消息从NT端传送到UNIX端。建立从UNIX端到NT端的远程连接和以上相仿,要建立双向的传输网络也是同样的道理。
  
  三.配置JNDI
  
  用JMS实现消息的发送和接收时,经常会用到JNDI。因为JNDI这种方式比较灵活,对于编程也比较简单。
  在安装了MQSeries Client for Java之后,在\java\bin目录下找到JMSAdmin.config文件。该文件主要用来说明Context的存储方式及存储地址,对应于文件中的两个参数INITIAL_CONTEXT_FACTORY和PROVIDER_URL。典型的JMSAdmin.config文件内容如下:
  
  #INITIAL_CONTEXT_FACTORY=com.sun.jndi.ldap.LdapCtxFactory
  INITIAL_CONTEXT_FACTORY=com.sun.jndi.fscontext.RefFSContextFactory
  #INITIAL_CONTEXT_FACTORY=com.ibm.ejs.ns.jndi.CNInitialContextFactory
  #
  #PROVIDER_URL=ldap://polaris/o=ibm,c=us
  PROVIDER_URL=file:/d:/temp
网管论坛bbs_bitsCN_com

  #PROVIDER_URL=iiop://localhost/
  #
  SECURITY_AUTHENTICATION=none
  
  INITIAL_CONTEXT_FACTORY表示JMSAdmin Tool使用的服务提供商。当前有三种受支持的值。com.sun.jndi.ldap.LdapCtxFactory用于LDAP,如果使用它就必须安装一个LDAP服务器。com.sun.jndi.fscontext.RefFSContextFactory用于文件系统上下文,它只需要使用者提供存放上下文的文件路径。com.ibm.ejs.ns.jndi.CNInitialContextFactory是专门为websphere提供的,它需要和websphere的CosNaming资源库一起使用。
  PROVIDER_URL表示会话初始上下文的URL,由JMSAdmin tool实现的所有JNDI操作的根。它和INITIAL_CONTEXT_FACTORY一一对应。
  
  ldap://hostname/contextname 用于LDAP
  file:[drive:]/path

TAGs   关于   介绍   队列   管理   DEFINE   创建   REPLACE   消息   QNAME      
 上一篇:JCreator Pro 2.5与WTK2.2配置(上)   下一篇:分享:轻松维护RDF元数据模型(图)
相关文章列表
介绍关于IBM MQSeries的使用指南 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
1.Myeclipse4.0 Tomcat5.0 j2sdk
2.Axis2 中的工具wsdl2Java 的使用点滴
3.J2EE体系结构
4.介绍关于IBM MQSeries的使用指南
5.怎么样配置Weblogic的数据源
6.struts+spring+ibatis轻量级J2EE开发
7.你能过关吗?J2EE面试题集锦(附答案)
8.使用Socket连接穿越CMWAP代理
9.Java/J2EE中文问题终极解决之道
10.用OSCache提升J2EE系统运行性能
最新推荐文章:
1.J2EE中SQL语句自动构造方法
2.J2EE系统优化之对象与循环
3.经验交流:学习J2EE流程中的经验和教训
4.基于NetBeans 比较Java EE 5平台和J2EE 1
5.初学者如何开发出一个高质量J2EE系统
6.编写JSR-168 Portlet指南
7.基于J2EE的电子商务开发模型及其实现
8.JNI调用C/C++方法从控制台输入密码
9.在NetBeans 4.1中使用Swing组件
10.Java EE/J2EE面向对象编程之道
网管论坛交流:
·不疯魔不成活
·令你大开眼界的真正标准化机房,已整理重
·为赈灾,女孩舍身拍“裸照”
·Windows Server 2003服务器群集创建和配
·exchange2k3全套官方资料
·双儿一周岁了。。。特殊的礼物来啦。。
·存储备份技术版块守则
·无盘技术交流区守则
·DOS命令基础大全之命令详解<作者吐血
·Windows XP 操作系统默认设置需要注意的