分析运行时行为、进程边界和 IPC 机制,检测"协议漂移"风险和进程生命周期问题。
71
Quality
55%
Does it follow best practices?
Impact
100%
1.16xAverage score across 3 eval scenarios
Optimize this skill with Tessl
npx tessl skill review --optimize ./.trae/skills/runtime-inspector/SKILL.md"代码会骗人,但进程不会。一个
.spawn()暴露的比一千行注释还多。" —— 老窃听者箴言
本技能的工作是追踪进程间的通信线路。
老师傅核心定律: 如果两个进程说话,但没人规定它们说什么语言、什么版本、什么格式,那就是一场等待爆发的协议漂移 (Protocol Mismatch) 灾难。
[!IMPORTANT] 在执行任何分析之前,你必须调用
sequential thinking工具,视情况进行 3—5 步推理。 思考内容例如:
- "这个项目有多少个入口点(
main函数)?它们是一个进程还是多个?"- "进程之间用什么通信?Pipe?HTTP?共享数据库?"
- "如果我只更新了 A 进程的通信模块,B 进程会崩吗?有版本握手吗?"
识别运行时边界 (Runtime Boundaries) 和 通信契约 (Communication Contracts)。
每个 main 函数可能代表一个独立的进程。
fn main(), #[tokio::main]if __name__ == "__main__":require.main === module, package.json 的 binfunc main()如果进程 A 拉起了进程 B,这就是一条"血缘线"。
Command::new(...), std::process::Stdio, tauri-plugin-shellsubprocess.Popen, multiprocessing.Processchild_process.spawn, child_process.fork进程之间用什么"说话"?协议在哪里定义?
搜索 Channels (通道):
Pipe, NamedPipe, unix_stream, zmqTcpListener, UdpSocket, websocket, http::server搜索 Protocols (协议):
Handshake, Version, MagicBytes, schemaprotobuf, serde_json, JSON.parse, enum Message老师傅核心判断 (Contract Status):
| 发现 | 状态 | 老师傅建议 |
|---|---|---|
找到 Channel + 找到 enum Message 或 Protobuf 定义 | 🟢 Strong | 契约存在,相对安全。 |
找到 Channel + 找到 Version 或 Handshake 检查 | 🟢 Strong | 有版本协商,很好。 |
| 找到 Channel + 只有 raw JSON/字符串 | 🟡 Weak | 无显式契约。改动一端可能炸另一端。 |
| 找到 Channel + 无任何协议定义 | 🔴 None | 通信黑洞! 这是高危风险。 |
| 风险模式 | 检测特征 | 老师傅建议 |
|---|---|---|
| 协议漂移 (Protocol Mismatch) | Channel 存在,但无 Handshake/Version | 在新功能规划中强制添加版本握手任务 |
| 僵尸进程 (Zombie Child) | spawn 存在,但无 Kill on Drop 或心跳 | 标记进程生命周期管理风险 |
| 单点故障 (SPOF) | 一个进程管控所有 IPC,无容错 | 建议添加重连/重启逻辑 |
| Named Pipe 权限漏洞 (Windows) | 使用 Named Pipe 但未显式设置 Security Descriptor | 🔴 高危:默认可能允许 Everyone 访问! |
| 竞态条件 (Race Condition) | 多进程快速交互,无明确的消息顺序控制 | 建议添加消息序列号或锁机制 |
[Strong / Weak / None],并说明依据。3069d33
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.