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)
相关推荐
花酒锄作田20 小时前
Pydantic校验配置文件
python
hboot20 小时前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi1 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi1 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽1 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187911 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
Warson_L2 天前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅2 天前
海天线算法的前世今生
python·计算机视觉
韩师傅2 天前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉
Warson_L2 天前
LangGraph的MessageState and HumanMessage
python