要实现Zabbix LLD监控,通常需要两个脚本,一个自定义发现check脚本,并输出成Json格式,另一个才是获取监控项values的脚本。
自定义发现checks脚本输出结果为以下形式:
{ "data": [ { "{#APP_NAME}": "AppCMDB" }, { "{#APP_NAME}": "AppMerchantWebApi" }, { "{#APP_NAME}": "AppNOC" }, { "{#APP_NAME}": "AppSSO" } ]}
用python写这样的脚本非常方便,那么如何用shell写呢?
先看一个实例:
公司需要生生产服务器的APP进程进行监控,监控项为CPU使用率、内存使用大小和进程启动数。
App目录都放在/workspace/carkey/ 目录下
root@localhost:/workspace/carkey# lsaaa AppCMDB AppNOC AppSSO AppYunboWeb get_app.shapache-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格式:
{ "data": [ { "{#APP_NAME}": "AppCMDB" }, { "{#APP_NAME}": "AppMerchantWebApi" }, { "{#APP_NAME}": "AppNOC" }, { "{#APP_NAME}": "AppSSO" } ]}
以下是shell脚本内容:
#!/bin/bashexport LANG=en_US.UTF-8unset LC_ALLa=(`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") fidonelength=${#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 ',' fidoneprintf "\n\t]\n"printf "}\n"
shell中主要是利用数组来实现的,这里就整理下数组的基本知识。
1、数组的定义
[root@PMS001 ~]# a=(1 2 3 4 5)[root@PMS001 ~]# echo $a1[root@PMS001 ~]# echo ${a[*]}1 2 3 4 5[root@PMS001 ~]# echo ${a[@]}1 2 3 4 5
一对括号表示数组,数组元素用“空格”符号分隔开。查看数组所有元素,用${a[*]}或者${a[@]}
2、通过下标查看数组中的某个元素
[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、获取数组长度
[root@PMS001 ~]# echo ${#a[@]}5[root@PMS001 ~]# echo ${#a[*]}5
4、数组赋值
[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、数组追加元素
[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脚本:
#!/usr/bin/env pythonimport commands,jsonapp_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"] = lisprint json.dumps(data,sort_keys=True, indent=4)
参考资料:http://www.cnblogs.com/chengmo/archive/2010/09/30/1839632.html