每月5万次额度不够用?飞书API过度调用问题终于解决了
最近有个朋友找到我,说他在飞书开发者后台发现了一个严重问题:/open-apis/bot/v3/info 这个接口每分钟被调用好几百次,每个月 5 万次的免费额度眼看就要用光了!

问题是怎么发现的
朋友在飞书开发者后台的「API 调用统计」里看到,bot/v3/info 这个接口的调用量异常高:
| 指标 | 数值 |
| 日调用次数 | 43200+ 次 |
| 每分钟调用 | ~300 次 |
| 月消耗估算 | 接近 5 万次上限 |
他都懵了:我就一个机器人,怎么调用这么频繁?
问题根因分析
我帮他排查了 OpenClaw 的飞书扩展代码,发现问题出在两个地方:
1. 状态检查触发 API 调用
每次查询机器人状态时,都会调用 probeFeishu() 函数去请求飞书的 bot info 接口。这个函数在以下场景会被调用:
- 启动机器人时获取 OpenID
- 外部系统查询状态时
- WebSocket 断线重连时
2. 缺乏缓存机制
原来的代码是「每次调用都发请求」,没有任何缓存。哪怕连续查询 10 次状态,就会产生 10 次 API 调用。
解决方案:5分钟缓存机制
我给 probe.ts 加了一个简单的缓存层:
// 缓存配置:5分钟内不重复调用 API
const CACHE_TTL_MS = 5 * 60 * 1000;
const botInfoCache = new Map();
核心逻辑很简单:
- 首次调用 → 请求飞书 API → 缓存结果
- 5 分钟内再次调用 → 直接返回缓存(不发起新请求)
- 失败结果也缓存 → 避免失败时重复请求
修改后的效果
| 对比项 | 修改前 | 修改后 |
|---|---|---|
| 每次状态查询 | 调用 API | 直接返回缓存 |
| 失败重试 | 无限重试 | 缓存 5 分钟 |
| 月消耗估算 | 50000+ 次 | ~300 次 |
简单算一笔账:每 5 分钟最多调用 1 次,一天 24 小时 = 288 次/月,一年才 3500 次左右。原来的 5 万/月额度,根本用不完!
适用场景
这个方案特别适合以下情况:
- 使用 OpenClaw 飞书扩展的用户
- 自己开发飞书机器人,频繁调用 bot info 接口
- API 额度告急,想优化调用次数
总结
飞书 API 过度调用的问题,本质上是缺乏缓存机制导致的。解决方案也很简单:给接口调用加个缓存。
有时候,最简单的优化反而是最有效的。
延伸阅读:
OpenClaw 3.23紧急修复!控制台文件漏打包引发崩溃
这次不是升级,是救火。OpenClaw 3.23 因为控制台文件漏打包,导致不少用户直接崩溃。先别慌,问题可快速修复,你...
AI 圈炸裂一周!OpenAI 高管离职、ChatGPT 成人模式跳票、AI Agent 杀疯了
这周的 AI 圈简直不要太热闹!OpenAI 内部地震、谷歌天价薪酬、AI Agent 遍地开花... 来,带你一文 g...
Claude Code /loop 炸场!一台电脑化身无数小龙虾,开发者彻底解放
如果你还在手动重复执行相同的 coding 任务,那你可能已经 out 了。Claude Code 最新推出的 /loo...
如何解决OpenClaw不能调用百炼的问题
如何解决OpenClaw不能调用百炼的问题这个问题困扰了我很久,现在终于解决了!如果你也遇到OpenClaw无法调用阿里...
OpenCLAW官宣入驻微博,国产AI大厂集体打 call
今天,一个重磅消息在科技圈炸开了锅——开源AI智能体平台 OpenCLAW 正式宣布入驻微博!消息一出,立即引发了业界的...