最近在做zabbix的二次開發;發現zabbix在做自動化方便提供了強悍的支持,下面分享下CMDB和zabbix打通,把CMDB平臺裏面的所有機器同步到zabbix數據庫,然後進行批量的模板綁定:
開發環境:
zabbix :2.4
python:flask框架.前端bootstrap,jquey:
實現思路:
一、
在CMDB表和ZAbbix主機表裏面建立第三張管理的表(定義叫緩存表);利用zabbix API把數據庫裏面的host插入到第三張緩存表;然後通過和CMDB庫裏面的比較把沒有在緩存表裏的數據插入到緩存表,再同步到zabbix 數據庫。
二、
綁定模板使用host.update 這個API,但是這個API在綁定後面的模板之後會刪除已經綁定的模板,所以這裏我們先遍歷出前面所有的模板,然後把前面和後面的一起綁定。
緩存表的models結構:
class ZbHost(db.Model): __tablename__ = 'zbhost' id = db.Column(db.Integer, primary_key=True) cmdb_hostid = db.Column(db.Integer, index=True, unique = True) hostid = db.Column(db.Integer, index=True, unique = True) host = db.Column(db.String(50)) ip = db.Column(db.String(32))
獲取數據:
def init_cmdb(): #取host (在server表裏) hosts = api_action("server.get") for h in hosts: data = {'cmdb_hostid':h['id']} db.session.query(ZbHost).filter_by(ip=h['inner_ip']).update(data) db.session.commit() #更新到cache表, ip def init_zabbix(): #第一步 取出所有host,要ip,host,id zb_hosts = zabbix_server.get_hosts() zb_hosts_interface = zabbix_server.get_interface([z['hostid'] for z in zb_hosts]) # data = [] for h in zb_hosts: h['ip'] = zb_hosts_interface[h['hostid']] # data.append(h) ###數據插入數據庫 db.session.add(ZbHost(**h)) db.session.commit()
同步主機到zabbix:
@main.route("/resource/monitor/ajax/sync_host_to_zabbix", methods=['POST']) def sync_host_to_zabbix(): #接收參數 #hostid groupid if request.method == "POST": from app.common.zabbix import create_zabbix_host params = dict(request.form) hostids = params['hostids'][0].split(',') ret = create_zabbix_host(hostids=params['hostids'][0].split(','),groupid=params['groupid'][0]) if len(ret) == len(hostids): return '1' else: return json.dumps(ret) return "500"
zabbix 界面:
到這裏同步主機完成;下面的批量綁定模板:
def link_template(self, hostid, templateids): templates = [] for id in templateids: templates.append({"templateid": id}) print templates print hostid try: ret = self.zb.host.update(hostid=hostid, templates=templates) return ret except Exception as e: return e.message 視圖: @main.route("/monitor/ajax/link_zabbix_template", methods=['POST']) def link_zabbix_template(): from app.common.zabbix import link_template if request.method == "POST": #1、獲取前端數據 params = dict(request.form) #{'hostids': [u'10106'], 'template_ids': [u'10001']} hostids = params['hostids'][0].split(',') template_ids = params['template_ids'][0].split(',') ret_data = link_template(hostids, template_ids) error = None for r in ret_data: try: hostids.remove(r['hostids'][0]) except Exception, e: error = e.message if not hostids: return "1" else: return error return "500"
主機綁定模板:
綁定之後:
登錄zabbix查看:
到此zabbix基本的同步主機,綁定模板已經完成;zabbix提供了非常優秀的API,我們可以用來實現很多我們需要的功能;上面的步驟已經基本上完成了我們日常說需要的功能;當然還有解綁模板刪除主機,添加維護週期等等;