接上面的內容;zabbix監控機制中,通常主機出故障的時候會無限制的傳送報警郵件,容易讓人心煩;於是找到zabbix的維護週期,利用api建立乙個維護週期,當我們把主機修好之後再刪除維護,重新監控主機;考慮到維護主機都是臨時建立,這裡我定義了1-3個小時的維護週期不設定維護週期計畫任務,需要維護人員登入新增即可。
實現步驟:
1、我定義乙個第三方的表,用來前端展示;當新增維護週期時候往資料庫裡新增資料。
2、呼叫api來操作maintenance
3、定義host.update 這個新增狀態為非監控狀態(0表示監控,1表示不監控)
models表:
class maintenance(db.model):
__tablename__ = "maintenance"
id = db.column(db.integer, primary_key=true)
maintenance_name = db.column(db.string(50))
hostname = db.column(db.string(50), index=true)
maintenance_time = db.column(db.integer)
update_time = db.column(db.datetime)
實現**:
1、建立維護週期api操作
def create_maintenance(self, params):
return self.zb.maintenance.create(**params)
2、更新host status
def host_status(self, hostid, status):
return self.zb.host.update(hostid=hostid, status = status)
3、具體實現:
@main.route("/monitor/zabbix/maintenance/add", methods=["post"])
def maintenance_add():
data = dict(request.form)
#maintenance_name = data['maintenance_name'][0]
hostname = data["name"][0]
time_to_go = data["time"][0]
time_long = int(time_to_go) * 60 *60
ret = zabbix_server.get_hosts()
for host in ret:
if hostname == host["host"]:
hostids = host["hostid"]
try:
result = create_maintenance(maintenance_name,hostids,time_long)
result_data = zabbix_server.host_status(hostid=hostids, status="1")
except:
return "check your maintenance_name"
update_time = time.strftime("%y-%m-%d %h:%i:%s", time.localtime(time.time()))
add_data =
obj = maintenance(**add_data)
db.session.add(obj)
try:
db.session.commit()
except exception,e:
raise exception(e.message.split(")")[1])
return "1"
return "200"
實現效果:
1、前端新增維護週期:
2、檢視維護週期:
登入zabbix檢視:
3、檢視zabbix host 狀態(顯示為not monitored):
Zabbix二次開發 01基礎
最近有個想法 想做乙個zabbix資料的二次呈現,所以來寫一下zabbix的api的內容。先說下zabbix api的認證基礎。zabbix api開始扮演著越來越重要的角色,尤其是在整合第三方軟體和自動化日常任務時。zabbix api為批量操作 第三方軟體整合以及其他作用提供可程式設計介面。za...
Zabbix二次開發 01基礎
最近有個想法 想做乙個zabbix資料的二次呈現,所以來寫一下zabbix的api的內容。先說下zabbix api的認證基礎。zabbix api開始扮演著越來越重要的角色,尤其是在整合第三方軟體和自動化日常任務時。zabbix api為批量操作 第三方軟體整合以及其他作用提供可程式設計介面。za...
Zabbix二次開發時常用到zabbix資料庫字段
1 zabbix web頁面中 配置 動作 事件源 觸發器 中的狀態,這個是用來報警發郵件或簡訊的,在資料庫中表中可以直接修改,sql語句為 update zabbix.actions set status 1 where name email 欄位status值為1時是關閉,0時為啟用,name為...