要实现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)
|