zabbix使用snmp监控硬件设备
1,zabbix server或者proxy服务器上安装snmp服务并开启(如net-snmp工具)。
2,对被监控机器开启snmp服务,目前广泛使用的版本是2c,community一般是public。
3,在zabbix server或者proxy测试是否可以正常获取数据,
shell> snmpwalk -v 2c -c public <host IP> .(OID(可以是字符串也可是数字,最好是数字))
ps:snmpwalk会遍历OID下面的所有的值,所以会很多,我这里只是测试下可以连上服务器并能获取到值
4,在zabbix上添加要监控的主机,可以从网上下载相应的模板,进行添加。然后根据不同设备情况对item和trigger进行适度调整。
5,如果添加后,发下主机的item或者discovery报错,一般为:监控项找不到。这说明zabbix server或proxy的mib文件里面没有对应的值。需要自己添加mib文件
6,根据要监控的主机,去下载对应的mib文件,将文件上传的对应的proxy或者zabbix server,默认路径为:/usr/share/snmp/mibs/,之后将.mib后缀名改为.txt。需要重启系统才能生效。
7,脚本批量添加,需要修改zabbix地址,登录用户密码,主机组,模板,macros,proxy等相关名称,运行脚本即可,脚本是根据别人写的自己做了修改,适用于zabbix3.x版本,2.x版本需要调整几个地方。主机组需要提前创建好。
1 from pyzabbix import ZabbixAPI 2 import sys 3 4 def zabbix_add(hostname,server_ip,proxy_name,base_template,group_name,value1,value2,user,passw): 5 zapi = ZabbixAPI("http://zabbix.com") #3.X的zabbix地址 6 7 zapi.login(user, passw) #填写zabbix的登录用户名和密码 8 groups = zapi.hostgroup.get(filter={"name":group_name}) 9 tempaltes = zapi.template.get(filter={'host':base_template}) 10 proxy_id = zapi.proxy.get(filter={"host": proxy_name})[0]['proxyid'] 11 12 zapi.host.create(host=hostname,interfaces=[{"type":2,"main":1,"useip":1,"dns":"","ip":server_ip,"port":"161"}],proxy_hostid=proxy_id,groups=groups,templates=tempaltes,macros=[{"macro":value1,"value":value2}]) 13 """上面一行,端口号默认161,macro需要更改""" 14 16 """读取配置文件的信息""" 17 with open("D:\\config.txt",'r') as f: 18 host_group,macro_name,value_name,proxy,temp_name,file_path = f.readlines() 19 # print(type(host_group),macro_name,value_name,proxy,temp_name,file_path) 20 proxy = proxy.strip() 21 macro_name = macro_name.strip() 22 value_name = value_name.strip() 23 host_group = eval(host_group) 24 temp_name = eval(temp_name) 25 a = '' #后面几行是把Excel里的IP列表copy到一个txt文件中,然后将IP用,连接起来,当时单独这样写,是用来再拼接上双引号的,现在不需要这样做了。 26 with open(file_path,'r') as f: 27 for j in f.readlines(): 28 if len(j) == 0: 29 pass 30 else: 31 a =a+j.strip()+"," 32 ips = a[:-1] 33 # print(ips) #输出检验下 34 35 # with open('D:\\new2.txt','w') as f2: 36 # f2.write(a[:-1]) 37 lic = ips.split(',') 38 username = input("输入zabbix用户名") 39 passwd = input("密码:") 40 for i in lic: 41 zabbix_add(i,i,proxy,temp_name,host_group,macro_name,value_name,username,passwd) #proxy的全名称和模板名称
config文件如下:
1 'HP' 2 {$SNMP_COMMUNITY} 3 public4 zabbix-proxy11111.abc.com 5 'Template_HP_SNMP_Autodiscovery' 6 D:\\new1.txt
1是host group名,如果要添加多个,可以加在后面,用逗号分隔;
2不用解释了,可以在宏配置里看到
3是community字符串
4是proxy的全名称
5是模板名称,多个的话,以逗号间隔
6是IP信息文件
IP文件信息格式如下:
ip1
ip2
ip3
8,添加前最好先加到维护模式,谁知道后面会不会有一大堆告警。一般模板里的item或者discovery的时间间隔比较长,可能长时间获取不到数据,可以手动把时间间隔调短点,待验证数据能正常获取的话,再调回来。
9,模板里的item基本都是一些比较基本的信息,有价值的信息多数都是通过discovery获取的
已风扇为例,先获取到有多少个风扇,它的index,然后根据index获取每一台风扇的状态和speed。
再补充个,大量的主机去验证snmp是否已经开启并生效,用Python写个脚本去循环执行snmpwalk命令即可。