python查询nightingale监控

python 复制代码
import requests
import pandas as pd
import json
from openpyxl import load_workbook
from openpyxl.styles import Font, PatternFill, Alignment, Border, Side
from openpyxl.formatting.rule import DataBarRule
from datetime import datetime

BASE = "https://n9e.com"
TOKEN = "xxx  

headers = {
    "Authorization": f"Bearer {TOKEN}",
    "User-Agent": "Mozilla/5.0"
}

url = f"{BASE}/api/n9e/targets?query=&p=1&limit=500"

r = requests.get(url, headers=headers, timeout=20, allow_redirects=False)

print("HTTP 状态码:", r.status_code)

raw_json=r.text

# -------------------- 2.解析数据 --------------------
data = json.loads(raw_json)
host_list = data["dat"]["list"]

processed_data = []
for host in host_list:
    group_names = ",".join([g["name"] for g in host["group_objs"]]) if host["group_objs"] else ""
    tags_str = ",".join(host["tags"]) if host["tags"] else ""
    tags_map_str = ",".join([f"{k}={v}" for k, v in host["tags_maps"].items()]) if host["tags_maps"] else ""
    update_time = datetime.fromtimestamp(host["update_at"]).strftime("%Y-%m-%d %H:%M:%S")
    mem_util = round(host["mem_util"],2)
    cpu_util = round(host["cpu_util"],2)

    processed_data.append({
        "机器ID": host["id"],
        "主机标识": host["ident"],
        "业务组": group_names,
        "主机IP": host["host_ip"],
        "操作系统": host["os"],
        "架构": host["arch"],
        "CPU核数": host["cpu_num"],
        "CPU使用率%": cpu_util,
        "内存使用率%": mem_util,
        "Agent版本": host["agent_version"],
        "采集引擎": host["engine_name"],
        "标签": tags_str,
        "标签明细": tags_map_str,
        "更新时间": update_time,
        "来源IP": host["remote_addr"],
        "备注": host["note"]
    })

df = pd.DataFrame(processed_data)
df1 = df.sort_values("内存使用率%",ascending=False).reset_index(drop=True)

DS_ID   = 3

# ✅ 注意:PromQL 里的双引号要保留,URL 会自动编码
promql = (
    'disk_used_percent'
    '{'
    'ProjEnv="PRO",'
    'path!~"/Library.*|/Volumes.*|/System.*|/private.*|/sys.*"'
    '}'
)

r = requests.get(
    f"{BASE}/api/n9e/proxy/{DS_ID}/api/v1/query",
    params={"query": promql},
    headers=headers,
    timeout=15,
    verify=True   # 自签证书可临时 verify=False
)

print("HTTP status:", r.status_code)

# -------------------------- 2. 解析Prometheus JSON数据 --------------------------
# 加载JSON
data = json.loads(r.text)

# 提取结果列表
result_list = data["data"]["result"]

# 遍历数据,展开为结构化列表
processed_data = []
for item in result_list:
    # 1. 提取metric标签(自动展开所有标签为列)
    row_data = item["metric"].copy()
    # 2. 提取时间戳与指标值
    timestamp_raw, value_raw = item["value"]
    # 3. 时间戳转换为可读格式(Prometheus返回的是秒级时间戳)
    row_data["指标时间戳(秒)"] = timestamp_raw
    row_data["指标时间(可读)"] = datetime.fromtimestamp(timestamp_raw).strftime("%Y-%m-%d %H:%M:%S")
    # 4. 指标值转换为数值类型
    row_data["指标值"] = float(value_raw)
    # 5. 加入处理后列表
    processed_data.append(row_data)

# 转换为DataFrame
df2 = pd.DataFrame(processed_data)

# -------------------------- 3. 生成美化Excel文件 --------------------------
result_df = pd.merge(
    df2, 
    df1, 
    left_on='ident', 
    right_on='主机标识', 
    how='left'
)
col_names = [result_df.columns[i] for i in [6,10,11,14,20,21]]
df3=result_df[col_names]
with pd.ExcelWriter('n9e监控.xlsx', engine='openpyxl') as writer:
    df1.to_excel(writer, sheet_name='cpu内存', index=False)
    df2.to_excel(writer, sheet_name='disk_used_percent', index=False)
    df3.to_excel(writer, sheet_name='汇总', index=False)
相关推荐
TechWayfarer4 小时前
IP画像在企业安全中的应用:它能做什么?不能替代什么
网络·python·tcp/ip·安全·网络安全
Rauser Mack5 小时前
不懂编程,但是vibe coding一个扫雷游戏
人工智能·python·游戏·html·prompt
郝学胜-神的一滴5 小时前
Python 高级编程 019:类变量与实例变量彻底解析
开发语言·python·程序人生·软件构建
CTA量化套保5 小时前
期货量化临期合约还能不能做:程序化到期禁开与强平写法
python·区块链
量化君也5 小时前
快速入门量化交易都要学些什么?
大数据·人工智能·python·算法·金融
吴卫斌5 小时前
行业ETF轮动策略实战(二):精选候选池——打造你的赛道武器库
大数据·python·股票·量化交易
Tbisnic5 小时前
AI大模型学习 第十天:让程序“指挥”大模型 —— 从对话到工具调用
人工智能·python·ai·大模型·react·cot·提示词工程
伊布拉西莫5 小时前
Flask 请求生命周期
后端·python·flask