python-Django监控系统二次开发Nagios
1、Nagios安装
yum install -y nagios.i686
yum install -y nagios-plugins-all.i686
安装完后会在apache的配置文件目录下/etc/httpd/conf.d/产生一个外部的配置文件nagios.conf
service httpd start
service nagios start
default user nagiosadmin password nagiosadmin
2.配置文件生成器
Django前期的收集主机信息代码
优化后:
#!/usr/bin/env python import urllib,urllib2
from subprocess import Popen,PIPE
import pickle
import json def getIfconfig():
p = Popen(['ifconfig'],stdout=PIPE)
data = p.stdout.read()
return data def getDmi():
p = Popen(['dmidecode'],stdout=PIPE,stderr=PIPE)
data_out = p.stdout.read()
data_err = p.stderr.read()
if data_err:
return {'vendor':'container','product':'container','sn':'XXX'}
return data_out def parseData(data):
if isinstance(data,dict):
return data
parsed_data = []
new_line = ''
data = [i for i in data.split('\n') if i]
for line in data:
if line[0].strip():
parsed_data.append(new_line)
new_line = line +'\n'
else:
new_line += line+'\n'
parsed_data.append(new_line)
return [i for i in parsed_data if i] def parseIfconfig(parsed_data):
parsed_data = [i for i in parsed_data if not i.startswith('lo')]
for lines in parsed_data:
line_list = lines.split('\n')
devname = line_list[0].split()[0]
macaddr = line_list[0].split()[-1]
ipaddr = line_list[1].split()[1].split(':')[1]
break
dic['ip'] =ipaddr
return dic def parseDmi(parsed_data):
if isinstance(parsed_data,dict):
return parsed_data
dic = {}
parsed_data = [i for i in parsed_data if i.startswith('System Information')]
parsed_data = [i for i in parsed_data[0].split('\n')[1:] if i]
dmi_dic = dict([i.strip().split(':') for i in parsed_data])
dic['vendor'] = dmi_dic['Manufacturer'].strip()
dic['product'] = dmi_dic['Product Name'].strip()
dic['sn'] = dmi_dic['Serial Number'].strip()[:15]
return dic def getHostname(f):
with open(f) as fd:
for line in fd:
if line.startswith('HOSTNAME'):
hostname = line.split('=')[1].strip()
break
return {'hostname':hostname} def getOsver(f):
with open(f) as fd:
for line in fd:
osver = line.strip()
break
return {'osver':osver} def getCpu(f):
num = 0
with open(f) as fd:
for line in fd:
if line.startswith('processor'):
num +=1
if line.startswith('model name'):
cpu_model = line.split(':')[1].split()
cpu_model = cpu_model[0]+' '+cpu_model[-1]
return {'cpu_num':num,'cpu_model':cpu_model} def getMemory(f):
with open(f) as fd:
for line in fd:
if line.startswith('MemTotal'):
mem = int(line.split()[1].strip())
break
mem = "%d" % int(mem/1024.0)+'M'
return {'memory':mem} if __name__ == '__main__':
dic = {}
data_ip = getIfconfig()
parsed_data_ip = parseData(data_ip)
ip = parseIfconfig(parsed_data_ip)
data_dmi = getDmi()
parsed_data_dmi = parseData(data_dmi)
dmi = parseDmi(parsed_data_dmi)
hostname = getHostname('/etc/sysconfig/network')
osver = getOsver('/etc/issue')
cpu = getCpu('/proc/cpuinfo')
mem = getMemory('/proc/meminfo')
dic.update(ip)
dic.update(dmi)
dic.update(hostname)
dic.update(osver)
dic.update(cpu)
dic.update(mem)
#data = urllib.urlencode(dic)
#data = pickle.dumps(dic)
data = json.dumps(dic)
req = urllib2.urlopen('http://192.168.1.120:8000/hostinfo/collect/',data)
print req.read()
在nagios上分组
vim gen.py
#!/usr/bin/env python import os
import urllib,urllib2
import json CUR_DIR = os.path.dirname(__file__)
CONF_DIR = os.path.join(os.path.abspath(CUR_DIR),'hosts') HOST_TEMP="""define host{
use linux-server
host_name %(hostname)s
alias %(hostname)s
address %(ip)s
}
"""
HOSTGROUP_TEMP="""define hostgroup{
hostgroup_name %(groupname)s
alias %(groupname)s
members %(members)s
}
"""
def initDir():
if not os.path.exists(CONF_DIR):
os.mkdir(CONF_DIR) def getData():
url = 'http://192.168.1.120:8000/hostinfo/getjson/'
req = urllib2.urlopen(url)
data = json.loads(req.read())
return data def writeConf(f,data):
with open(f,'w') as fd:
fd.write(data) def parseData(data):
host_conf = ''
hostgroup_conf = ''
for hg in data:
groupname = hg['groupname']
members = []
for h in hg['members']:
hostname = h['hostname']
members.append(hostname)
host_conf += HOST_TEMP % h
hostgroup_conf += HOSTGROUP_TEMP % {'groupname':groupname, 'members':','.join(members)}
fp_hostconf = os.path.join(CONF_DIR,'hosts.cfg')
fp_hostgroupconf = os.path.join(CONF_DIR,'hostgroup.cfg')
writeConf(fp_hostconf,host_conf)
writeConf(fp_hostgroupconf,hostgroup_conf) if __name__ == '__main__':
initDir()
data = getData()
parseData(data)
gen.py
同步配置文件sync_gen.sh
#!/bin/bash cur=`dirname $0`
cd $cur
python gen.py
md5=`find hosts/ -type f -exec md5sum {} \;|md5sum`
cd /etc/nagios/conf.d
conf_md5=`find hosts/ -type f -exec md5sum {} \;|md5sum`
if [ "$md5" != "$conf_md5" ];then
cd -
cp -rp hosts/ /etc/nagios/conf.d
/etc/init.d/nagios restart
fi
如果两个分组都有一样的信息,即一样的主机名,则需加判断条件:
#!/usr/bin/env python import os
import urllib,urllib2
import json CUR_DIR = os.path.dirname(__file__)
CONF_DIR = os.path.join(os.path.abspath(CUR_DIR),'hosts') HOST_TEMP="""define host{
use linux-server
host_name %(hostname)s
alias %(hostname)s
address %(ip)s
}
"""
HOSTGROUP_TEMP="""define hostgroup{
hostgroup_name %(groupname)s
alias %(groupname)s
members %(members)s
}
"""
def initDir():
if not os.path.exists(CONF_DIR):
os.mkdir(CONF_DIR) def getData():
url = 'http://192.168.1.120:8000/hostinfo/getjson/'
req = urllib2.urlopen(url)
data = json.loads(req.read())
return data def writeConf(f,data):
with open(f,'w') as fd:
fd.write(data) def countDict(k,d):
if k in d:
d[k] += 1
else:
d[k] = 1 def parseData(data):
dic = {}
host_conf = ''
hostgroup_conf = ''
for hg in data:
groupname = hg['groupname']
members = []
for h in hg['members']:
hostname = h['hostname']
members.append(hostname)
countDict(hostname,dic)
if dic(hostname) < 2:
host_conf += HOST_TEMP % h
hostgroup_conf += HOSTGROUP_TEMP % {'groupname':groupname, 'members':','.join(members)}
fp_hostconf = os.path.join(CONF_DIR,'hosts.cfg')
fp_hostgroupconf = os.path.join(CONF_DIR,'hostgroup.cfg')
writeConf(fp_hostconf,host_conf)
writeConf(fp_hostgroupconf,hostgroup_conf) if __name__ == '__main__':
initDir()
data = getData()
parseData(data)
python-Django监控系统二次开发Nagios的更多相关文章
- Epicor系统二次开发
Epicor系统二次开发 一.获取或修改界面EpiDataView的字段数据(Get EpiDataView data) C# EpiDataView edv = (EpiDataView)oTran ...
- (dede)织梦系统二次开发笔记
(dede)织梦系统二次开发记录 --soulsjie 一.模板常用文件说明 模板文件都在文件夹templets下,我们以默认模板(default)为例,对模板文件结构进行分析: 首页模板文件目录 \ ...
- 开源监控系统中 Zabbix 和 Nagios 哪个更好?
监控平台的话,各有优劣,但基本都可以满足需求.等达到一定监控指标后,发现,最困难的是监控项目的管理. CMDB中小规模(服务器<=1k):Zabbix大规模(1k>=服务器<=10k ...
- IBOS云办公系统二次开发之功能介绍(PHP技术)
IBOS自动化办公系统是我见到的功能.架构最好的开源自动化办公系统,功能与企业需求吻合度之高.架构之灵活,让我不得不将之介绍给大家,让跟多需要学习PHP开发的朋友来了解她,拥抱她! 如果您还没有很好的 ...
- Python Django 学习 (二) 【Django 模型】
注: 由于自己排版确实很难看,本文开始使用markdown编辑,希望有所改善 官方定义 A model is the single, definitive source of information ...
- Ecshop系统二次开发教程及流程演示
来源:互联网 作者:佚名 时间:03-01 16:05:31 [大 中 小] Ecshop想必大家不会觉得陌生吧,大部分的B2C独立网店系统都用的是Ecshop系统,很受用户的喜爱,但是由于Ecs ...
- python的Web框架,Django模型系统二,模型属性,及数据库进阶查询
原始数据接上篇文章来操作.可能需要查看后才能懂.点击这里查看 1.常用的模型字段类型 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fie ...
- 用Python+Django在Eclipse环境下开发web网站【转】
一.创建一个项目如果这是你第一次使用Django,那么你必须进行一些初始设置.也就是通过自动生成代码来建立一个Django项目--一个Django项目的设置集,包含了数据库配置.Django详细选项设 ...
- 用Python+Django在Eclipse环境下开发web网站
一.创建一个项目如果这是你第一次使用Django,那么你必须进行一些初始设置.也就是通过自动生成代码来建立一个Django项目--一个Django项目的设置集,包含了数据库配置.Django详细选项设 ...
随机推荐
- 四边形不等式优化DP——石子合并问题 学习笔记
好方啊马上就要区域赛了连DP都不会QAQ 毛子青<动态规划算法的优化技巧>论文里面提到了一类问题:石子合并. n堆石子.现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆石子合并成新的 ...
- postman是如何使用的?
1.地址:https://segmentfault.com/a/1190000005055899
- IOS中UITableView异步加载图片的实现
本文转载至 http://blog.csdn.net/enuola/article/details/8639404 最近做一个项目,需要用到UITableView异步加载图片的例子,看到网上有一个E ...
- spring BeanFactory加载xml配置文件示例
项目目录结构如下: HelloWorld.java package com.thief.demo; public class HelloWorld { public void sayHello() { ...
- GitHub从无到有
一步一步教你如何在GitHub上上传自己的项目 2018年07月04日 09:23:40 夏雨薇安 阅读数:22764 首先你得注册一个自己的GitHub账号,注册网址:https://githu ...
- LINQ分页工具
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Co ...
- Image Recognition
https://www.tensorflow.org/tutorials/image_recognition
- Qt状态机框架(状态机就开始异步的运行了,也就是说,它成为了我们应用程序事件循环的一部分了)
状态机框架 Qt中的状态机框架为我们提供了很多的API和类,使我们能更容易的在自己的应用程序中集成状态动画.这个框架是和Qt的元对象系统机密结合在一起的.比如,各个状态之间的转换是通过信号触发的,状态 ...
- Delphi中Message消息的三种使用方法(覆盖WndProc,覆盖消息函数,改写WMCommand)
实例1 unit Unit1; interfaceuses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Fo ...
- 我的Android进阶之旅------>/storage/sdcard0, /sdcard, /mnt/sdcard ,/storage/emulated/legacy 的区别
转自:http://bbs.gfan.com/android-5382920-1-1.html 关于android的4.2的0文件夹的详解---- android 4.0 ----在galaxy ne ...