cxwpf200 发表于 2018-1-1 19:04:21

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版本需要调整几个地方。主机组需要提前创建好。
  

from pyzabbix import ZabbixAPI  

import sys  

  
def zabbix_add(hostname,server_ip,proxy_name,base_template,group_name,value1,value2,user,passw):
  
   zapi = ZabbixAPI("http://zabbix.com")   #3.X的zabbix地址
  

  
   zapi.login(user, passw)   #填写zabbix的登录用户名和密码
  
   groups = zapi.hostgroup.get(filter={"name":group_name})
  
   tempaltes = zapi.template.get(filter={'host':base_template})
  
   proxy_id = zapi.proxy.get(filter={"host": proxy_name})['proxyid']
  

  
   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}])
  
"""上面一行,端口号默认161,macro需要更改"""
  

  
"""读取配置文件的信息"""
  
with open("D:\\config.txt",'r') as f:
  
   host_group,macro_name,value_name,proxy,temp_name,file_path = f.readlines()
  
# print(type(host_group),macro_name,value_name,proxy,temp_name,file_path)
  
proxy = proxy.strip()
  
macro_name = macro_name.strip()
  
value_name = value_name.strip()
  
host_group = eval(host_group)
  
temp_name = eval(temp_name)
  
a = ''  #后面几行是把Excel里的IP列表copy到一个txt文件中,然后将IP用,连接起来,当时单独这样写,是用来再拼接上双引号的,现在不需要这样做了。
  
with open(file_path,'r') as f:
  
   for j in f.readlines():
  
         if len(j) == 0:
  
             pass
  
         else:
  
             a =a+j.strip()+","
  
ips = a[:-1]
  
# print(ips)   #输出检验下
  

  
# with open('D:\\new2.txt','w') as f2:
  
#   f2.write(a[:-1])
  
lic = ips.split(',')
  
username = input("输入zabbix用户名")
  
passwd = input("密码:")
  
for i in lic:
  
   zabbix_add(i,i,proxy,temp_name,host_group,macro_name,value_name,username,passwd) #proxy的全名称和模板名称
  

  config文件如下:
  

'HP'  
{$SNMP_COMMUNITY}
  
public zabbix-proxy11111.abc.com
  
'Template_HP_SNMP_Autodiscovery'
  
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命令即可。
  
页: [1]
查看完整版本: zabbix使用snmp监控硬件设备