遇到个websphere MQ监控的问题,希望通过命令行的方式获取到MQ的一些状态:

1. su - mqm 使用mqm用户

2. dspmq 最简单的命令,查看队列控制器的状态:

$ dspmq -m MQXXX999
QMNAME(MQXXX999)                                          STATUS(Running)


现在问题来了,如何在其他用户(root)下,直接获取到“Running”这个字段?


在下bash基础不好,经历了这么几个过程:

1. 使用su -c的方式,指定mqm用户来执行相应命令:

# su - mqm -c 'echo "dis qmstatus conns" | runmqsc MQXXX999'
5724-H72 (C) Copyright IBM Corp. 1994, 2009.  ALL RIGHTS RESERVED.
Starting MQSC for queue manager MQXXX999.
     1 : dis qmstatus conns
AMQ8705: Display Queue Manager Status Details.
   QMNAME(MQXXX999)                        STATUS(RUNNING)
   CONNS(6)                            
One MQSC command read.
No commands have a syntax error.
All valid MQSC commands were processed.

2. 使用grep 取得相应的行:

# su - mqm -c 'echo "dis qmstatus conns" | runmqsc MQXXX999' | grep CONNS
   CONNS(6)

3. 使用sed正则表达式提取其中的数字6:

# su - mqm -c 'echo "dis qmstatus conns" | runmqsc MQXXX999' | grep CONNS | sed "s/.*CONNS(\([0-9]*\)).*/\1/g"
6

对于sed里使用正则表达式,结合这里的使用实例再解释一下:

sed "s/.*CONNS(\([0-9]*\)).*/\1/g"

1. 使用s/pattern1(pattern2)pattern3/\1/g  的方式, \1 代表提取括号里pattern2的部分

2. (pattern2)的括号是正则表达式里的运算符,要转义,就变成\(pattern2\)

3. 对应于CONNS(6), CONNS(   的pattern是 .*CONNS( ,   ) 对应pattern是).*  这样确保默认贪婪的正则匹配不会匹配到下一个括号前的内容

4. 需要提取的括号中的内容,pattern2, 使用[0-9a-zA-Z]*的方式,我在aix上的sed不支持\w, \d这样的写法


于是,得到了以上的整行完整命令。


再举一个例子:

# su - mqm -c 'echo "dis qmstatus conns" | runmqsc MQXXX999' | grep QMNAME                                           
   QMNAME(MQXXX999)                        STATUS(RUNNING)
# su - mqm -c 'echo "dis qmstatus conns" | runmqsc MQXXX999' | grep QMNAME | sed "s/.*QMNAME(\([0-9a-zA-Z]*\)).*/\1/g"
MQXXX999