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命令即可。


posted @ 2017-09-17 14:36  露似真珠月似弓  阅读(20665)  评论(1编辑  收藏  举报