# -*- coding: utf-8 -*- """轮询第三次执行结果。""" from __future__ import annotations import json import sys import time from pathlib import Path import requests TOKEN_FILE = Path(__file__).parent / ".monitor_token" BASE = "http://localhost:8000" EXECUTION_ID = "abc94b2d-615f-42ea-83cc-ce687524a6ea" REFRESH_TOKEN = ( "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9." "eyJzdWIiOiIxIiwic2l0ZV9pZCI6Mjc5MDY4NTQxNTQ0MzI2OSwidHlwZSI6InJlZnJlc2giLCJleHAiOjE3NzIyNjM0NjN9." "XYoda5lfxNtTSAGWoLlYhS9cA-hTK9iqK0SqUyn2KV4" ) def refresh_token() -> str: resp = requests.post(f"{BASE}/api/auth/refresh", json={"refresh_token": REFRESH_TOKEN}, timeout=10) if resp.status_code != 200: print(f"❌ 刷新失败: {resp.status_code}") sys.exit(1) t = resp.json()["access_token"] TOKEN_FILE.write_text(t, encoding="utf-8") return t TOKEN = refresh_token() HEADERS = {"Authorization": f"Bearer {TOKEN}", "Content-Type": "application/json"} for i in range(90): # 最多 30 分钟 time.sleep(20) mm, ss = divmod((i + 1) * 20, 60) try: r = requests.get(f"{BASE}/api/execution/history?limit=5", headers=HEADERS, timeout=15) if r.status_code == 401: TOKEN = refresh_token() HEADERS["Authorization"] = f"Bearer {TOKEN}" continue if r.status_code != 200: continue target = next((h for h in r.json() if h["id"] == EXECUTION_ID), None) if not target: print(f"[{mm}m{ss}s] 等待...") continue status = target.get("status") dur = target.get("duration_ms") dur_s = f"{dur/1000:.1f}s" if dur else "—" if status in ("success", "failed", "cancelled"): print(f"🏁 status={status}, 耗时={dur_s}, exit_code={target.get('exit_code')}") # 获取日志 lr = requests.get(f"{BASE}/api/execution/{EXECUTION_ID}/logs", headers=HEADERS, timeout=30) if lr.status_code == 200: ld = lr.json() from _env_paths import get_output_path out = get_output_path("SYSTEM_LOG_ROOT") (out / "2026-02-21__etl_run_raw_v3.json").write_text( json.dumps(ld, ensure_ascii=False, indent=2), encoding="utf-8" ) print(f"日志已保存") el = (ld.get("error_log") or "").strip().split("\n") print("--- error_log 末尾 80 行 ---") for line in el[-80:]: print(line) break print(f"[{mm}m{ss}s] status={status}") except Exception as e: print(f"[{mm}m{ss}s] {e}") else: print("超时")