基础概念
对于MQ,咱们须要知道4个名词:队列管理器、队列、消息、通道;对于编程设计人员,一般更关心消息和队列,对于维护管理人员,一般 会更关心队列管理器和通道。若是咱们把队列管理器比做是数据库,那么队列就是其中的一张表,消息就是表中的一条记录。
队列:咱们能够简单地把队列当作一个容器,用于存放消息。 数据库
队列管理器:队列管理器构建了独立的 MQ 的运行环境,它是消息队列的管理者,用来维护和管理消息队列。 编程
消息:MQ中的最小对象;默认状况下,消息缺省能够达到 4MB。消息能够分红持久消息和非持久消息。所谓“持久”的 意思,就是在MQ 队列管理器重启动后,消息是否仍然能保持。持久的消息写入或读出队列的同时会在 Log 中记录,因此性能上比非持久消息差很多。 服务器
通道:通道则是两个队列管理器之间的一种单向的点对点的通讯链接, 消息在通道中只能单向流动。队列管理器之间的通讯是经过配置通道来实现 的,通道两侧的队列管理器对这个通道的相关参数应该能对应起来。在通道上能够配置不一样的通讯协议,这样就使得编程接口与通讯协议无关。通道两端的 配置必须匹配,且名字相同,不然没法连通。 并发
RUNMQSC:命令行交互界面管理工具;做为维护人员的咱们,与MQ打交道有两种方式,一种是经过MQ提供的二进制命令工具(在mq安装目录的bin目录下),另外一种方式则是经过命令行交互管理工具;这两者在功能上有不少是重合的,但并不是彻底可替代;RUNMQSC是一个通用的 MQ 对象管理工具,使用 MQSC命令集能够对 MQ 对象进行全方位的管理,也是各类管理方式最直接、最全面的一种。RUNMQSC 运行的命令集称为 MQSC (MQ Script Command)";在 RUNMQSC 中大小写无关,全部的命令会先转换成全大写再提交执行。因此若是要 表示大小相关的字串,好比对象名,则用引号将字串包住。输入如下命令启动MQSC命令:runmqsc [queueManagerName] tcp
--查看MQ版本-- 工具
dspmqver 性能
--查看队列状态--
dspmq 测试
--建立队列管理器--
crtmqm -q ECIS_QM 命令行
--删除队列管理器--
dltmqm ECIS_QM 设计
--启动队列管理器--
strmqm ECIS_QM
--关闭队列管理器--
endmqm -i ECIS_QM 当即中止
endmqm -p ECIS_QM 强制中止
--运行队列管理器--
runmqsc ECIS_QM
--定义监听器--
DEFINE LISTENER(LSR_4_ECIS_QM) TRPTYPE(TCP) PORT(1616) CONTROL(QMGR) REPLACE
START LISTENER(LSR_4_ECIS_QM)
--定义通道--
DEFINE CHANNEL(ECIS.SVRCONN) CHLTYPE(SVRCONN) MCAUSER('mqm') REPLACE
--启动通道--
runmqchl –c ChlName –m ECIS_QM
--启动侦听--
runmqlsr –t TCP –p 1616 –m ECIS_QM
endmqlsr -m ECIS_QM
--定义队列--
DEFINE QL(Q_SVC2ADP_4_TELNET) REPLACE
DEFINE QL(Q_SVC2ADP_4_JDBC) REPLACE
DEFINE QL(Q_SVC2ADP_4_HTTP) REPLACE
DEFINE QL(Q_SVC2ADP_4_SOCKET) REPLACE
--删除队列--
delete QL(Q_SVC2ADP_4_TELNET)
--查看监听器--
display listener (LSR_4_ECIS_QM)
--查看通道--
dis chs(*)
--查看通道--
display ql(*) [all]
--查看队列深度--
display ql(Q_SVC2ADP_4_HTTP) curdepth
--清除队列消息--
clear ql(Q_SVC2ADP_4_HTTP)
--查看CCSID--
display qmgr all
--修改CCSID--
ALTER QMGR [FORCE] CCSID(5488)
逻辑定义
##################################################
./JMSAdmin
DELETE QCF(T_ECIS_QCF)
DELETE Q(T_ECIS_Q_SVC2ADP_TELNET)
DELETE Q(T_ECIS_Q_ADP2SVC_TELNET)
DELETE Q(T_ECIS_Q_SVC2ADP_JDBC)
DELETE Q(T_ECIS_Q_ADP2SVC_JDBC)
DELETE Q(T_ECIS_Q_SVC2ADP_HTTP)
DELETE Q(T_ECIS_Q_ADP2SVC_HTTP)
DELETE Q(T_ECIS_Q_SVC2ADP_SOCKET)
DELETE Q(T_ECIS_Q_ADP2SVC_SOCKET)
DEFINE QCF(T_ECIS_QCF) DESC() TRAN(CLIENT) HOST(10.151.128.13) QMGR(T_ECIS_QM) CHAN(T_ECIS.SVRCONN) PORT(2626) CCSID(5488)
DEFINE Q(T_ECIS_Q_SVC2ADP_TELNET) DESC() QMGR(T_ECIS_QM) QUEUE(Q_SVC2ADP_4_TELNET) CCSID(5488)
DEFINE Q(T_ECIS_Q_ADP2SVC_TELNET) DESC() QMGR(T_ECIS_QM) QUEUE(Q_ADP2SVC_4_TELNET) CCSID(5488)
DEFINE Q(T_ECIS_Q_SVC2ADP_JDBC) DESC() QMGR(T_ECIS_QM) QUEUE(Q_SVC2ADP_4_JDBC) CCSID(5488)
DEFINE Q(T_ECIS_Q_ADP2SVC_JDBC) DESC() QMGR(T_ECIS_QM) QUEUE(Q_ADP2SVC_4_JDBC) CCSID(5488)
DEFINE Q(T_ECIS_Q_SVC2ADP_HTTP) DESC() QMGR(T_ECIS_QM) QUEUE(Q_SVC2ADP_4_HTTP) CCSID(5488)
DEFINE Q(T_ECIS_Q_ADP2SVC_HTTP) DESC() QMGR(T_ECIS_QM) QUEUE(Q_ADP2SVC_4_HTTP) CCSID(5488)
DEFINE Q(T_ECIS_Q_SVC2ADP_SOCKET) DESC() QMGR(T_ECIS_QM) QUEUE(Q_SVC2ADP_4_SOCKET) CCSID(5488)
DEFINE Q(T_ECIS_Q_ADP2SVC_SOCKET) DESC() QMGR(T_ECIS_QM) QUEUE(Q_ADP2SVC_4_SOCKET) CCSID(5488)
WebSphere MQ经常使用命令及配置
##################################################
//建立本地队列Q
DEFINE QLOCAL (Q)
//将本地队列Q 的最大深度设置为5
ALTER QLOCAL (Q) MAXDEPTH(5)
//从新建立本地队列Q 若是Q已经存在,则将其所有属性重置为缺省属性
DEFINE QLOCAL (Q) REPLACE
//建立远程队列
DEFINE QREMOTE(QRNAME) RNAME(AAA) RQMNAME(QMGRNAME) XMITQ(QTNAME)
//建立传输队列
define qlocal(CLV_HQ_TRAN) usage(xmitq) INITQ(SYSTEM.CHANNEL.INITQ) TRIGDATA(REV_CLV) TRIGTYPE(EVERY) TRIGGER REPLACE
//建立接收端通道C
DEFINE CHANNEL(C) CHLTYPE(RCVR)
//建立发送方通道C ,链接对方的IP为10.10.10.10 端口为1414 通道链接的传输队列为XQ
DEFINE CHANNEL(C) CHLTYPE(SDR) CONNAME(’10.10.10.10 (1414)’) XMITQ(XQ)
//建立请求方通道
DEFINE CHANNEL(D) CHLTYPE(RQSTR) CONNAME(’10.10.10.10 (1414)’)
//建立服务器通道
DEFINE CHANNEL (D) CHLTYPE(SVR) xmitq (XQ1)
//建立服务器链接通道
DEFINE CHANNEL(E) CHLTYPE(SVRCONN) REPLACE
//显示全部远程队列
display qremote (*)
//显示全部通道
Display channel (*)
//定义死信队列
DEFINE QLOCAL(QUEUE) DEFPSIST(YES) REPLACE
//设定队列管理器的死信队列
ALTER QMGR DEADQ(QUEUE)
设置MaxChannels和MaxActiveChannels属性(最大链接数)
##################################################
MaxChannels和MaxActiveChannels分别表明队列管理器容许配置的通道的最大个数和容许同时运行的通道的个数,MaxChannels的缺省值是100,MaxActiveChannels的缺省值与MaxChannels相同。若是您的并发通道链接个数超过了100,您须要修改这两个参数。这对于大并发的Client/Server间通信尤其重要。
在unix平台,修改qm.ini文件,添加以下所示(路径:/var/mqm/qmgrs/HQ_SVR):
Channels:
MaxChannels = 3000 (最大通道数)
MaxActiveChannels = 3000 (最大活动通道数)
PipeLineLength=2
AdoptNewMCA=ALL
而后重启MQ
//定义持久性队列:
DEFINE QLOCAL(QNAME) DEFPSIST (YES) REPLACE
传输队列管理
##################################################
1:定义传输队列
DEFINE QLOCAL(Q_TRANSFER) USAGE(XMITQ)
注:
Q_TRANSFER:传输队列名
下面定义一个输入队列并带触发器
DEFINE QLOCAL(Q_TRANSFER) USAGE(XMITQ) DEFPSIST(YES) INITQ(SYSTEM.CHANNEL.INITQ) TRIGDATA(DP_RCHANNEL) REPLACE
注:
参数1:传输队列名称(Q_TRANSFER)
参数5:触发器数据(DP_RCHANNEL),也就是触发后要启动的通道。
2:在传输入队列上定义触发器
DPCIS_Q_TRANSFER:传输队列
触发器数据:DP_RCHANNEL,即:发送通道,触发时启动该通道
alter qlocal(DPCIS_Q_TRANSFER) TRIGDATA('DP_RCHANNEL') TRIGTYPE(every) TRIGGER initq('SYSTEM.CHANNEL.INITQ')
远程队列管理
##################################################
经过输入如下命令来定义远程队列定义:
define qremote(Q1) rname(Q1) rqmname(QM_APPLE) xmitq(QM_APPLE)
注:
参数1:队列名称(发送方远程队列名)
参数2:远程队列(接收方的本地接收队列名)
参数3:远程队列管理器(接收方队列管理器名)
参数4:传输队列(发送方传输队列名)
通道管理
##################################################
1:建立接收方通道
DEFINE CHANNEL(SDR_ TEST) CHLTYPE(RCVR) REPLACE
define channel(Q_R_CHANNEL2) chltype(RCVR) replace
注:
参数1:接收方通道名称
replace:表示有该通道了替换
2:建立发送方通道
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(DP_RCHANNEL) chltype(SDR) conname('10.101.2.3 (1414)') xmitq(Q_TRANSFER) replace
注:
通道名称:DP_RCHANNEL (发送方通道的名称)
传输队列:Q_TRANSFER (发送方传输队列的名称)
3:启动通道
start channel(QM_ORANGE.QM_APPLE)
4:查看通道状态
dis chs(*)
侦听器管理
##################################################
1:定义侦听器
DEFINE LISTENER(TCPLS1) TRPTYPE(TCP) PORT(1414) REPLACE
2:启动侦听器
start listener(TCPLS1)
3:显示侦听器信息
display listener(tcpls1)
建立触发
##################################################
通常设置MQ触发器的目的有两种, 一是自动启动发送端通道, 二是监视队列消息, 一旦发现新的消息, 则利用触发器启动相应的处理进程
若是是利用触发器自动启动发送端通道, 使用方法1, 若是是利用触发器启动用户进程, 使用方法2
方法1
A 在传输通道上设置触发器, 打开触发器控制, 类型为"第一个"
B 初始队列为SYSTEM.CHANNEL.INITQ, 该队列为MQ专用的通道启动队列, 不须要手工启动其触发监视器
C 触发器数据为发送端通道名称, 例如 QAG.50
D 在发送端通道不活动的状况下, 在传输通道放入消息测试
方法2
A 建立一个触发启动队列, 其模板为SYSTEM.DEFAULT.INITIATION.QUEUE
runmqsc
define qlocal (MQ.TRIGER.INIQUEUE) like (SYSTEM.DEFAULT.INITIATION.QUEUE)
B 定义进程 所谓进程就是触发器要触发的程序本例中进程名称:TRIGER.PROGRAM 应用程序标识为:"Notepad.exe"
C 在队列上设置触发器, 通常为本地队列, 打开触发器控制, 类型根据本身的须要选择"第一个", "每一个" 仍是 "根据消息数量"
D 初始队列选择A中建立的触发启动队列, 例如MQ.TRIGER.INIQUEUE, 进程名称设置为B中定义的进程名称, 例如TRIGER.PROGRAM
E 启动触发监视器 runmqtrm -m QAGWY -q MQ.TRIGER.INIQUEUE
F 在本地队列放入消息进行测试
方法2也能够完成方法1的工做, 只须要将进程定义中的应用程序标识改成 runmqchl -m QAGWY -c QAG.50 就能够了, 但MQ中提供了专用的通道启动队列, 而该队列不须要手工启动触发监视器, 所以方法1比方法2的步骤要少, 配置也简单, 因此在利用触发器自动启动发送端通道的状况下, 仍是方法1更好.