zabbix 二次開發之同步CMDB主機和模板綁定

    最近在做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"


wKioL1bqe-qQ6vR2AAAqSuGlM8k873.png

zabbix 界面:

wKioL1bqfCywW0ePAAC9f6m3iSg482.png


到這裏同步主機完成;下面的批量綁定模板:

 

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"


主機綁定模板:

wKioL1bqfumC2u1aAABFXZgf36w607.png



綁定之後:

wKiom1bqfqHxuYrpAAAlFDe3dGA172.png


登錄zabbix查看:


wKioL1bqf6ewS8fZAADKvWPk_IM045.png


     到此zabbix基本的同步主機,綁定模板已經完成;zabbix提供了非常優秀的API,我們可以用來實現很多我們需要的功能;上面的步驟已經基本上完成了我們日常說需要的功能;當然還有解綁模板刪除主機,添加維護週期等等;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章