自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

探索Zabbix API(三):導(dǎo)出主機(jī)組資源使用率

開(kāi)發(fā) 前端
文章描寫了 Zabbix API 的腳本通過(guò)與用戶交互,動(dòng)態(tài)獲取 Zabbix 中主機(jī)組的信息,對(duì)用戶選擇的特定主機(jī)組,獲取該主機(jī)組內(nèi)主機(jī)的基本信息以及 CPU 使用率,并將這些信息導(dǎo)出到 CSV 文件中。

今天我們來(lái)講一下探索zabbixAPI的最后一章,結(jié)合前兩章的內(nèi)容,導(dǎo)出指定主機(jī)組的資源使用情況。

01、使用場(chǎng)景

通過(guò)該腳本,系統(tǒng)管理員和運(yùn)維團(tuán)隊(duì)可以定期分析系統(tǒng)中特定主機(jī)組的性能數(shù)據(jù),包括主機(jī)的基本信息和 CPU 使用率。這有助于識(shí)別系統(tǒng)中的性能瓶頸、監(jiān)測(cè)系統(tǒng)資源的使用情況,并及時(shí)采取措施進(jìn)行優(yōu)化。

02、導(dǎo)出數(shù)據(jù)的方法介紹

1.時(shí)間函數(shù),用途取監(jiān)控時(shí)間范圍

x = (datetime.datetime.now() - datetime.timedelta(hours=12)).strftime("%Y-%m-%d %H:%M:%S")
y = (datetime.datetime.now()).strftime("%Y-%m-%d %H:%M:%S")
z = (time.strftime('%Y-%m-%d %H-%M-%S'))
def timestamp(x, y):
    p = time.strptime(x, "%Y-%m-%d %H:%M:%S")
    starttime = str(int(time.mktime(p)))
    q = time.strptime(y, "%Y-%m-%d %H:%M:%S")
    endtime = str(int(time.mktime(q)))
    return starttime, endtime

函數(shù)解析:

x: 表示當(dāng)前時(shí)間減去 12 小時(shí)的時(shí)間,以字符串形式表示。這一時(shí)間字符串的格式為 "%Y-%m-%d %H:%M:%S",即年-月-日 時(shí):分:秒。

y: 表示當(dāng)前時(shí)間,以字符串形式表示,同樣使用 "%Y-%m-%d %H:%M:%S" 格式。

z: 使用 time.strftime 函數(shù)獲取當(dāng)前時(shí)間的字符串表示,格式為 "%Y-%m-%d %H-%M-%S",即年-月-日 時(shí)-分-秒。

timestamp函數(shù)首先使用 time.strptime 函數(shù)將時(shí)間字符串轉(zhuǎn)換為結(jié)構(gòu)化的時(shí)間元組。然后,通過(guò) time.mktime 函數(shù)將時(shí)間元組轉(zhuǎn)換為時(shí)間戳,并使用 str 函數(shù)將時(shí)間戳轉(zhuǎn)換為字符串。

2.獲取指定監(jiān)控項(xiàng)的ID

Cpu_load="system.cpu.util[]"
def get_cpu_utilization(host_id, auth):
    data = {
        "jsonrpc": "2.0",
        "method": "item.get",
        "params": {
            "output": "extend",
            "hostids": host_id,
            "search": {
                "key_": Cpu_load  
            },
            "sortfield": "name"
        },
        "auth": auth,
        "id": 1
    }


    response = requests.post(url=ApiUrl, headers=header, jsnotallow=data)
    result = json.loads(response.content)
    items = result["result"]

函數(shù)解析:

函數(shù)首先獲取與主機(jī)關(guān)聯(lián)的監(jiān)控項(xiàng),然后從中找到 CPU 使用率相關(guān)的監(jiān)控項(xiàng)。

Cpu_load:表示要獲取的主機(jī)監(jiān)控項(xiàng)的key值(可以在對(duì)應(yīng)主機(jī)的監(jiān)控項(xiàng)中查看,這里選的是CPU使用率)

get_cpu_utilization(host_id, auth): 這個(gè)函數(shù)用于獲取指定主機(jī)的 CPU 使用率。它首先通過(guò) Zabbix API 中的 item.get 方法獲取主機(jī)的監(jiān)控項(xiàng)列表,然后從中找到與 CPU 使用率相關(guān)的監(jiān)控項(xiàng),并獲取其歷史數(shù)據(jù)。最終,返回一個(gè)包含 CPU 使用率歷史數(shù)據(jù)的列表。

host_id: 主機(jī)的ID,表示要獲取 CPU 使用率的主機(jī)。

auth: 認(rèn)證令牌,用于通過(guò) Zabbix API 進(jìn)行身份驗(yàn)證。

3.獲取歷史數(shù)據(jù)函數(shù)

def get_item_history(item_id, auth):
    data = {
        "jsonrpc": "2.0",
        "method": "history.get",
        "params": {
            "output": "extend",
            "itemids": item_id,
            "history": 0,  # 0代表數(shù)值型數(shù)據(jù)
            "sortfield": "clock",
            "sortorder": "DESC",
            "limit": 1
        },
        "auth": auth,
        "id": 1
    }


    response = requests.post(url=ApiUrl, headers=header, jsnotallow=data)
    result = json.loads(response.content)
    history_data = result["result"]
    return history_data

函數(shù)解析:

函數(shù)通過(guò) Zabbix API 發(fā)送請(qǐng)求,拿到歷史數(shù)據(jù),然后將其返回供后續(xù)使用。

get_item_history(item_id, auth): 這個(gè)函數(shù)用于獲取指定監(jiān)控項(xiàng)(item)的歷史數(shù)據(jù)。它構(gòu)建了一個(gè) JSON-RPC 請(qǐng)求,其中包括監(jiān)控項(xiàng)的 item_id,并通過(guò) Zabbix API 中的 history.get 方法獲取歷史數(shù)據(jù)。該函數(shù)返回一個(gè)包含歷史數(shù)據(jù)的列表。

item_id: 監(jiān)控項(xiàng)的ID,表示要獲取歷史數(shù)據(jù)的監(jiān)控項(xiàng)。

4.獲取主機(jī)信息喝資源使用率并導(dǎo)入以主機(jī)組名命名的CSV文件中

def export_host_info(token, start, end, group_names, group_name_num2):
    filename = f'{group_name_num2}.csv'


    with open(filename, 'w', newline='', encoding='utf-8-sig') as f:
        writer = csv.DictWriter(f, fieldnames=["Group", "Hostname", "IP", "CPU使用率"])
        writer.writeheader()


        for group in group_names:
            if group['name'] == group_name_num2:
                group_id = group['groupid']
                group_name = group['name']
                hosts = get_hosts_in_group(group_id, token)


                for host in hosts:
                    hostname = host['name']
                    ip = host['interfaces'][0]['ip']
                    cpu_utilization = get_cpu_utilization(host['hostid'], token)


                    cpu_value = cpu_utilization[0]['value'] if cpu_utilization else "N/A"


                    writer.writerow({"Group": group_name, "Hostname": hostname, "IP": ip, "CPU使用率": cpu_value})

函數(shù)解析:

filename: 通過(guò)使用用戶選擇的主機(jī)組名(group_name_num2)作為文件名的一部分創(chuàng)建 CSV 文件的名稱。打開(kāi) CSV 文件,并使用 csv.DictWriter 對(duì)象創(chuàng)建一個(gè) CSV 寫入器,定義了列名為 ["Group", "Hostname", "IP", "CPU使用率"]。

寫入 CSV 文件的表頭行。遍歷主機(jī)組信息,找到用戶選擇的主機(jī)(group_name_num2)。獲取該主機(jī)組內(nèi)的所有主機(jī)信息,遍歷每個(gè)主機(jī)。對(duì)于每個(gè)主機(jī),獲取主機(jī)名(hostname)、IP地址(ip)和對(duì)應(yīng)的 CPU 使用率(cpu_value)。

將這些信息寫入主機(jī)組命名的 CSV 文件。

5.打印所有主機(jī)組名,根據(jù)用戶輸入模糊匹配列表輸出,供用戶參考輸入。根據(jù)用戶的輸入獲取準(zhǔn)確的主機(jī)組名

def get_zabbix_data():
    token = get_token()
    start, end = timestamp(x, y)


    # Get and display the list of host groups
    host_group_list = []
    group_names = get_group_name(token)
    for index, group in enumerate(group_names, start=1):
        host_group_list.append(f"{index}.{group['name']}")
    print(host_group_list)


    # User input and selection
    group_name = input("請(qǐng)輸入zabbix主機(jī)組名稱: ")
    result = fuzzy_match_list(group_name, host_group_list)
    print(result)


    group_name_num = input("請(qǐng)輸入要查詢的主機(jī)組序號(hào): ")


    # Get user-selected host group information
    group_name_num1 = host_group_list[int(group_name_num) - 1]
    group_name_num2 = group_name_num1.split(".")[1]
    print(group_name_num2)


    return token, start, end, group_names, group_name_num2
    
#調(diào)用 get_zabbix_data 函數(shù)獲取認(rèn)證令牌、時(shí)間范圍、主機(jī)組列表和用戶選擇的主機(jī)組名。
token, start, end, group_names, group_name_num2 = get_zabbix_data()
#調(diào)用 export_host_info 函數(shù),將獲取的信息寫入 CSV 文件。
export_host_info(token, start, end, group_names, group_name_num2)

函數(shù)解析:

調(diào)用 get_token 獲取 Zabbix API 的認(rèn)證令牌 token。

調(diào)用 timestamp(x, y) 獲取時(shí)間范圍的起始時(shí)間戳 start 和結(jié)束時(shí)間戳 end。

獲取并輸出主機(jī)組列表,用戶輸入所需的主機(jī)組名稱。

使用 fuzzy_match_list 函數(shù)對(duì)用戶輸入的主機(jī)組名稱進(jìn)行模糊匹配,輸出匹配結(jié)果。

用戶輸入要查詢的主機(jī)組序號(hào),計(jì)算用戶想要的主機(jī)組的序號(hào)(group_name_num1),然后裁剪掉序號(hào)前面的部分得到用戶選擇的主機(jī)組名(group_name_num2)。

最后使用兩段代碼完成調(diào)用。

token, start, end, group_names, group_name_num2 = get_zabbix_data()

export_host_info(token, start, end, group_names, group_name_num2)

03、結(jié)論

文章描寫了 Zabbix API 的腳本通過(guò)與用戶交互,動(dòng)態(tài)獲取 Zabbix 中主機(jī)組的信息,對(duì)用戶選擇的特定主機(jī)組,獲取該主機(jī)組內(nèi)主機(jī)的基本信息以及 CPU 使用率,并將這些信息導(dǎo)出到 CSV 文件中。通過(guò) Zabbix 的認(rèn)證令牌,以及時(shí)間范圍的設(shè)置,使得用戶可以根據(jù)自己的需求靈活地查詢和導(dǎo)出監(jiān)控?cái)?shù)據(jù)。從而更好地了解和管理系統(tǒng)的性能。

責(zé)任編輯:武曉燕 來(lái)源: 新鈦云服
相關(guān)推薦

2023-11-29 08:03:46

Zabbix APIPython

2013-04-12 09:39:01

Top監(jiān)控系統(tǒng)

2015-01-05 14:07:27

云計(jì)算虛擬化云環(huán)境

2024-04-11 13:27:19

Linuxtop命令

2016-10-11 08:33:32

服務(wù)器使用率多線程

2011-04-06 11:36:30

MRTG監(jiān)控內(nèi)存

2015-04-27 09:29:48

微軟AzureIaaS混合IT

2009-11-16 17:03:20

Oracle優(yōu)化CPU

2019-01-15 15:04:54

CPU電腦使用率

2009-01-13 16:41:02

編程語(yǔ)言JavaC

2021-08-10 11:45:57

topCPULinux

2022-07-23 21:31:24

KubernetesLinux開(kāi)源

2021-05-31 15:53:57

CPU Top命令

2024-05-14 08:47:01

JavaPAC++

2014-05-09 10:42:38

GNULinux

2012-12-28 11:46:35

手機(jī)系統(tǒng)iOS黑莓

2012-05-30 16:32:34

谷歌瀏覽器IE

2011-08-24 14:35:35

Platform

2019-09-12 08:03:56

MySQL索引數(shù)據(jù)庫(kù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)