要实现Zabbix LLD监控,通常需要两个脚本,一个自定义发现check脚本,并输出成Json格式,另一个才是获取监控项values的脚本。
自定义发现checks脚本输出结果为以下形式:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
{ "data" : [
{
"{#APP_NAME}" : "AppCMDB"
},
{
"{#APP_NAME}" : "AppMerchantWebApi"
},
{
"{#APP_NAME}" : "AppNOC"
},
{
"{#APP_NAME}" : "AppSSO"
}
]
} |
用python写这样的脚本非常方便,那么如何用shell写呢?
先看一个实例:
公司需要生生产服务器的APP进程进行监控,监控项为CPU使用率、内存使用大小和进程启动数。
App目录都放在/workspace/carkey/ 目录下
1
2
3
|
root@localhost: /workspace/carkey # ls
aaa AppCMDB AppNOC AppSSO AppYunboWeb get_app.sh apache-tomcat-8.0.28 AppMerchantWebApi AppPms AppTest bbb.py |
所有App开头的目录都是公司APP目录,其他的不是。这些App都是JAVA程序,启动后进程名可以通过
ps -ef | grep App_name 匹配到,例如
[root@PMS001 ~]# ps -ef | grep AppPms
root 4698 1 0 Jul13 ? 00:00:28 /usr/java/latest/bin/java -Djava.util.logging.config.file=/workspace/carkey/AppPms/latest/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -server -XX:PermSize=256M -XX:MaxPermSize=1024m -Xms512M -Xmx1024M -XX:MaxNewSize=256m -Xms512M -Xmx1024M -server -XX:+UseParallelGC -Djava.endorsed.dirs=/usr/local/tomcat/endorsed -classpath /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/workspace/carkey/AppPms/latest -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/workspace/carkey/AppPms/latest/temp org.apache.catalina.startup.Bootstrap start
现需要对所有的App进程进行监控。所以,我们通过ls /workspace/carkey/ 命令来获取所有的进程名。并将进程名做成JSON格式:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
{ "data" : [
{
"{#APP_NAME}" : "AppCMDB"
},
{
"{#APP_NAME}" : "AppMerchantWebApi"
},
{
"{#APP_NAME}" : "AppNOC"
},
{
"{#APP_NAME}" : "AppSSO"
}
]
} |
以下是shell脚本内容:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
#!/bin/bash export LANG=en_US.UTF-8
unset LC_ALL
a=(` ls /workspace/carkey | grep "^App" 2> /dev/null `)
b=() for i in ${a[@]}; do
if [ ` ls /workspace/carkey/ $i | grep latest| wc -l` -gt 0 ]; then
b=( "${b[@]}" "$i" )
fi
done length=${ #b[@]}
printf "{\n"
printf '\t' "\"data\":["
for ((i=0;i<$length;i++))
do printf '\n\t\t{'
printf "\"{#APP_NAME}\":\"${b[$i]}\"}"
if [ $i -lt $[$length-1] ]; then
printf ','
fi
done printf "\n\t]\n"
printf "}\n"
|
shell中主要是利用数组来实现的,这里就整理下数组的基本知识。
1、数组的定义
1
2
3
4
5
6
7
|
[root@PMS001 ~] # a=(1 2 3 4 5)
[root@PMS001 ~] # echo $a
1 [root@PMS001 ~] # echo ${a[*]}
1 2 3 4 5 [root@PMS001 ~] # echo ${a[@]}
1 2 3 4 5 |
一对括号表示数组,数组元素用“空格”符号分隔开。查看数组所有元素,用${a[*]}或者${a[@]}
2、通过下标查看数组中的某个元素
1
2
3
4
5
6
7
|
[root@PMS001 ~] # echo ${a[0]}
1 [root@PMS001 ~] # echo ${a[1]}
2 [root@PMS001 ~] # echo ${a[4]}
5 [root@PMS001 ~] # echo ${a[5]}
|
数组是有序的,跟python中的列表和元组一样,数组的下标从0开始。
3、获取数组长度
1
2
3
4
|
[root@PMS001 ~] # echo ${#a[@]}
5 [root@PMS001 ~] # echo ${#a[*]}
5 |
4、数组赋值
1
2
3
4
5
|
[root@PMS001 ~] # a[1]=10
[root@PMS001 ~] # echo ${a[1]}
10 [root@PMS001 ~] # echo ${a[*]}
1 10 3 4 5 |
数组是可以修改的,这一点和python中的列表一样,但是python中的元组不可修改
5、删除
[root@PMS001 ~]# a=(1 2 3 4 5)
[root@PMS001 ~]# unset a
[root@PMS001 ~]# echo ${a[*]}
[root@PMS001 ~]# a=(1 2 3 4 5)
[root@PMS001 ~]# unset a[1]
[root@PMS001 ~]# echo ${a[*]}
1 3 4 5
6、替换
[root@PMS001 ~]# a=(1 2 3 4 5)
[root@PMS001 ~]# echo ${a[@]/3/10}
1 2 10 4 5
[root@PMS001 ~]# echo ${a[@]}
1 2 3 4 5
[root@PMS001 ~]# a=(${a[@]/3/10})
[root@PMS001
调用方法是:${数组名[@或*]/查找字符/替换字符} 该操作不会改变原先数组内容,如果需要修改,可以看上面例子,重新定义数据。
7、数组追加元素
1
2
3
4
5
6
7
8
9
|
[root@PMS001 ~] # b=(${b[@]} 1)
[root@PMS001 ~] # echo ${b[@]}
1 [root@PMS001 ~] # b=(${b[@]} 2)
[root@PMS001 ~] # echo ${b[@]}
1 2 [root@PMS001 ~] # b=(${b[@]} 3)
[root@PMS001 ~] # echo ${b[@]}
1 2 3 |
上面的shell脚本就是利用这个方法来重新生成一个数组,保存符合条件的App_name
python脚本:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
#!/usr/bin/env python import commands,json
app_str = commands.getoutput( 'ls /workspace/carkey/ |grep "^App"' )
new_app_list = [] app_list = app_str. split ( '\n' )
for I in app_list:
com = "ls /workspace/carkey/%s | grep latest" % I
commvalue=commands.getstatusoutput(com)
if commvalue[0] == 0:
new_app_list.append(I)
data={} lis=[] for App in new_app_list:
dic={}
dic[ "{#APP_NAME}" ] = App
lis.append(dic)
data[ "data" ] = lis
print json.dumps(data,sort_keys=True, indent=4)
|