如何实现SQL存储过程状态监控_编写实时运行监控仪表盘

张开发
2026/4/15 21:45:03 15 分钟阅读

分享文章

如何实现SQL存储过程状态监控_编写实时运行监控仪表盘
SQL Server 用 sys.dm_exec_requests 关联 sys.dm_exec_sql_text 查实时 SP 状态status 为 running/runnable/suspended 才算真执行PostgreSQL 用 pg_stat_activity.stateactive 结合 query 字段判断函数运行MySQL 需启用 performance_schema.events_statements_current 查 SP 当前行。SQL Server 中如何获取正在运行的存储过程状态直接查 sys.dm_exec_requests 和 sys.dm_exec_sql_text 是最可靠的方式它能实时反映当前正在执行的 SP包括阻塞、等待、CPU/IO 消耗比轮询 sysprocesses 或依赖 sp_who2 更准确、更轻量。必须关联 sql_handle 才能拿到实际执行的 SQL 文本否则只能看到 EXEC proc_name 这种外壳status 字段值为 running / runnable / suspended 才算“真正在跑”sleeping 是已结束但连接未释放别误判为卡死如果存储过程里用了 WAITFOR 或大事务wait_type 会显示 WAITFOR 或 LCK_M_*这是正常行为不是故障信号避免在高并发 OLTP 环境中每秒轮询——建议最小间隔设为 5 秒且加 WHERE command EXECUTE 过滤掉其他操作PostgreSQL 怎么监控函数执行状态PostgreSQL 没有内置的“正在运行的函数”视图得靠 pg_stat_activity pg_blocking_pids() 组合判断重点看 state、backend_start、state_change 三个字段。state active 表示后端正在执行某条语句但不保证是函数——需检查 query 字段是否包含 SELECT my_func() 或 CALL my_proc()函数内若调用 pg_sleep()state 仍为 active但 wait_event_type 会是 Client 或 Timeout不能单凭 state 判定卡死注意 pg_stat_activity 默认只对超级用户或同用户可见普通监控账号需授权GRANT SELECT ON pg_stat_activity TO monitor_role;不要依赖 backend_start 推算执行时长——它记录的是连接建立时间不是函数开始时间MySQL 存储过程运行中怎么查卡在哪一行MySQL 原生不支持行级执行点追踪INFORMATION_SCHEMA.PROCESSLIST 只显示“正在执行存储过程”但看不到具体语句位置。真正可行的是开启 performance_schema 并启用 events_statements_current 表。 Adobe Image Background Remover Adobe推出的图片背景移除工具

更多文章