如何使用Zabbix API批次修正主機名稱

乐维_lwops發表於2024-08-14

先說為什麼要修正?

這其實源自於Ansible安裝zabbix agent的一個小Bug。有小夥伴發現,利用ansible批次安裝zabbix agent後,zabbix系統上顯示的主機名出錯了,主機顯示的名稱都變成了作業系統的IP(如下圖),這在一定程度增加了維護難度。

KtQ3tGga66b491e0ee55d.png

如果一臺一臺去修改和校正主機名將會非常耗費時間,這時候就可以利用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表中的可見的名稱

WdTcd2Yv66b492d7a406a.png

3.2 提交API更新資料

修改指令碼引數

if __name__ == "__main__":

#main1() #註釋執行main1
main2() #mian2為從 zabbix_hosts.xlsx 檔案讀取更新後的資訊並提交到 Zabbix API 進行更新。

修改前:

MUUdbphY66b493070b787.png

修改後:

FvHnvgX066b493139107f.png

這樣我們就實現了利用Zabbix API 批次修改主機顯示的名稱。

相關文章