AI 装得越多越累?这个「通知防火墙」把 40 条噪音砍到 7 条
几乎每个星期,都会冒出一个新的“AI 助手”:帮你整理邮件、安排日程、跟进销售、审查代码、监控 Slack、总结会议……
我也装了一大堆。但有个真相,那些光鲜的发布帖不会告诉你:
这些工具并没有减少你的工作,它们只是在成倍增加你的通知。
每个 AI 都默认自己很“贴心”。“贴心”的意思就是:“我发现了个情况——快看通知!”当你堆了十几个这样的工具后,你面对的不再是“一个收件箱”,而是“十二个收件箱”。每新增一个 AI,你的信噪比反而变得更差。
主流建议是:“那你去设置里调一下啊。”
好吧,每装一个新工具,先花四小时调通知设置;等它更新“更智能的通知”功能后,再花四小时重新调。这不是提升效率,这是打着“配置”旗号的通知保洁工作。
这是个结构性问题,不是配置问题。
问错问题了
每个 AI 工具都在问同一个问题:“这件事重要吗?”
这是个错误的问题。世界上不存在客观的“重要”。重要与否取决于你此刻的状态。Stripe 的 Webhook 在你调试支付流程时很重要,但在你专注写代码时它就是噪音;联合创始人发来的 Slack 消息周二上午 11 点很关键,周五晚上 11 点却毫无意义。
真正该问的是:
这件事足够紧急吗?紧急到必须立刻打断我现在做的事?
这不是单个 AI 助手能回答的。这是一个凌驾于所有 AI 之上的层级。它们不知道你此刻在做什么,不知道其他 AI 在做什么,更不知道你接下来一小时打算怎么过。
于是它们全部默认:“我先发通知,你自己判断。”你就得到了现在的体验:被通知淹没。
真正的 AI 防火墙长什么样
我在做这样一层东西,它叫 Klorn。在实际使用中,每一条信息——不管是邮件、日程邀请、Agent 动作、Webhook 还是其他工具的推送——都要经过五道“安检门”:
- Silent(静默):只记录,不打扰,你随时能查。默认拦截一切噪音:营销邮件、GitHub 自动关闭的 Issue、Stripe 收款凭证、Vercel 部署成功提示。
- Queue(排队):收入每日摘要,不发手机推送。适合 Newsletter、日常通知汇总。
- Push(推送):只有极少数情况才发手机通知。比如有人回复了你正在等的邮件或线程。
- Call(电话):直接打电话,不接就升级。留给真正的紧急情况:生产环境挂了、家人急事。
- Auto-handle(自动处理):直接帮你把事情办了,事后给你一张“收据”供查阅。比如按规则自动接受会议邀请、自动填表、自动归档。
这五个层级怎么判断?Klorn 会看这几样东西:
- 联系人信任分:根据你过往的回复率、会议接受率、历史互动自动学习,而不是你写死就忘的规则
- 日历状态感知:你现在是在深度工作中、开会中、还是已经下班了?
- 真实紧急信号:而不是看主题行里有没有“URGENT”。说句实话,主题里写“紧急”的,往往最不紧急
- 按域名设置优先级:你只需设置一次,之后不用再碰
整体策略是“默认拒绝”。大多数事情都会被归为 Silent 或 Queue。Push 很罕见,Call 是稀缺资源,Auto-handle 则在你背后默默干完活。
为什么做这件事很“不合时宜”
做 AI 防火墙很不性感。投资人想要的是“能帮你干活的 AI Agent”。如果你在融资 PPT 上说“我建了一个系统,让它少干活、更安静”,听起来就像是倒着走。
但每个被我展示过的创始人,反应都只有一个:解脱。因为他们正在溺水。每一个买来的生产力工具,都让他们的注意力变得更差。AI Agent 的繁荣没有减少他们的工作量,只是抬高了背景通知的噪音底线。
AI 工具的默认设置本应该是:“闭嘴,除非真的重要。”
大多数工具做不到。所以我从外部建了一层防火墙,既然单个工具不会自我约束,那就由外部系统来强制执行。
现在做到哪了
目前是我单枪匹马开发的第 5 周,处于手动邀请制的内测阶段。代码也开放在了 GitHub 上,供人围观。我每天自己都用:邮件、日历和所有接入的 Agent 都经过 Klorn 过滤。以前我每天要接收 40 多条推送通知,现在只剩 3 到 7 条。那 40 多条不是因为我忘了关 Slack,而是当你同时运行多个 AI 工具和一个真实邮箱时,真实的噪音底数。
技术栈用的是 Next.js 15、TypeScript、Prisma、Postgres、Claude / OpenAI tool use,以及 Gmail 和 Google Calendar 的集成,部署在 Render 上。
一个真正的少数派观点
如果一个 AI 工具默认就发推送通知,那它就是坏的。不管它的推理能力多强,它都推不出一个被通知淹没的你。
未来 Agent 产品最有价值的部分,不会是更多的 Agent,而是那道防火墙——决定哪些 Agent 被允许打断你、什么时候可以打断你。
