设为首页 收藏本站
查看: 835|回复: 0

[经验分享] 介绍关于IBM MQSeries的使用指南

[复制链接]

尚未签到

发表于 2017-5-25 11:42:12 | 显示全部楼层 |阅读模式
  随着计算机网络和分布式应用的不断发展,远程消息传递越来越成为应用系统中不可缺少的组成部分。商业消息中间件的出现保证了消息传输的可靠性,高效率和安全性,同时也减少了系统的开发周期。目前应用最多的消息中间件产品为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
  如果是默认队列管理器,可以不带其名字
  
  往队列中放消息 中国网管论坛bbs.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)+ 网管u家bitscn.net
  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)
   网管u家bitscn.net
  更改属性
  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’)
网管联盟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
   中国网管论坛bbs.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下一般情况下在建立队列管理器时会自动建立侦听器,启动队列管理器时则会自动启动侦听程序。当然也可以手动配置侦听程序。
网管朋友网www_bitscn_net
  
  
  修改\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
网管u家www.bitscn.net
  
  #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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-380942-1-1.html 上篇帖子: IBM Rational软件开发高峰论坛散记 下篇帖子: IBM MQ 学习,简单配置实例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表