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详细选项设 ...
随机推荐
- COM对象模型
COM对象内存布局,多继承是虚继承吗? 接口之间怎么切换? 1) 是普通的多继承,不是虚继承.因为父类接口只是含有纯虚函数,不含任何数据成员,所以问题不大. 2) QueryInterface可以用来 ...
- Python中使用__new__实现单例模式并解析
阅读文章前请先阅读 Python中类方法.__new__方法和__init__方法解析 单例模式是一个经典设计模式,简要的说,一个类的单例模式就是它只能被实例化一次,实例变量在第一次实例化时就已经固定 ...
- Window系统下MongoDB安装及远程访问
1.编辑mongodb 安装文件夹bin\mongod.cfg 把bindIP 改为 127.0.0.1, 192.168.1.180(局域网IP) 可以参考https://blog.csdn.net ...
- M - 基础DP
M - 基础DP Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descriptio ...
- Java基础 - 变量转换
在java中变量转发分为两种,隐式转换和强制转换 隐式转换: byte a = 10; int b = 20; byte c = a + b; // 该方法会报错,转换过程中字节数只能从小变大,不能从 ...
- redis持久化RDB详细操作步骤
1.xshell远程登录服务器ssh root@192.168.142.130 2.切换到redis目录 3.创建一个配置文件s2-redis.conf 4.编辑文件 vi s2-redis.conf ...
- 12.Django数据库操作(执行原生SQL)
1.使用extra方法 解释:结果集修改器,一种提供额外查询参数的机制 说明:依赖model模型 用在where后: Book.objects.filter(publisher_id="1& ...
- 保护眼睛,win7家庭版如何修改窗口的背景颜色
win7的窗口背景色为白色,长时间使用电脑对眼睛的刺激比较大,为了保护眼睛建议改成浅灰色或者淡绿.淡黄色等,可是win7的家庭版里没有[个性化]菜单,那么我们如何修改呢? 首先在[开始]处找到[控制面 ...
- SQL优化小结
一 背景 客户数据库经常出现死锁.超时.查询慢等问题,数据库mssql,数据量主要表大概上千W. 二 收集信息 首先是要找出IO大.查询慢.使用频率高的脚本.直接用Profiler ...
- 编写你的第一个django应用程序4
本教程上接教程3,我们将继续开发网页投票应用,本部分将主要关注简单的表单处理以及如何对代码进行优化 写一个简单的表单 让我们更新一下在上一个教程中编写的投票详细页面的模板(‘polls/detail. ...