先說為什麼要修正?
這其實源自於Ansible安裝zabbix agent的一個小Bug。有小夥伴發現,利用ansible批次安裝zabbix agent後,zabbix系統上顯示的主機名出錯了,主機顯示的名稱都變成了作業系統的IP(如下圖),這在一定程度增加了維護難度。
如果一臺一臺去修改和校正主機名將會非常耗費時間,這時候就可以利用zabbix API批次修正主機名稱。如下:
1 環境準備
1.1 基礎環境:python3
具體安裝步驟參考網上教程。
1.2 python3第三方庫安裝:
pip install openpyxl requests
2 獲取主機清單
2.1 示例程式碼
import requests
import json
import openpyxl
# Zabbix伺服器的URL和認證資訊
zabbix_url = "http://zabbix_web訪問IP電子地址/zabbix/api_jsonrpc.php" #Zabbix web 訪問地址
zabbix_username = "zabbix使用者名稱稱"
zabbix_password = "zabbix使用者密碼"
# 獲取認證令牌
def get_auth_token():
payload = {
"jsonrpc": "2.0",
"method": "user.login",
"params": {
"user": zabbix_username,
"password": zabbix_password
},
"id": 1,
"auth": None
}
headers = {
'Content-Type': 'application/json-rpc',
}
response = requests.post(zabbix_url, headers=headers, data=json.dumps(payload))
result = response.json()
if 'result' in result:
return result['result']
else:
raise Exception(f"Error obtaining auth token: {result}")
# 獲取所有手動新增的主機物件(排除自動發現的主機)
def get_manual_hosts(auth_token):
payload = {
"jsonrpc": "2.0",
"method": "host.get",
"params": {
"output": ["hostid", "host", "name"], # 只獲取所需欄位
"filter": {
"flags": "0" # 只獲取手動新增的主機
}
2.2 程式碼引數修改
填寫zabbix API地址,使用者以及密碼
# Zabbix伺服器的URL和認證資訊
zabbix_url = "http://zabbix_web訪問IP電子地址/zabbix/api_jsonrpc.php" #Zabbix web 訪問地址,如:http://192.168.1.1/zabbix/api_jsonrpc.php
zabbix_username = "zabbix使用者名稱稱"
zabbix_password = "zabbix使用者密碼"
注:API地址為zabbix web訪問地址,如採用分散式部署(即zabbix web與 zabbix server不在同一臺伺服器),請勿填寫zabbix server伺服器地址。
2.3程式碼執行
python3 zabbixApi_hosts.py
#指令碼執行完畢後會在同級目錄生成一份excel表zabbix_hosts.xlsx
3 更新主機可見的名稱
3.1 修改excel表中的可見的名稱
3.2 提交API更新資料
修改指令碼引數
if __name__ == "__main__":
#main1() #註釋執行main1
main2() #mian2為從 zabbix_hosts.xlsx 檔案讀取更新後的資訊並提交到 Zabbix API 進行更新。
修改前:
修改後:
這樣我們就實現了利用Zabbix API 批次修改主機顯示的名稱。