<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>避坑指南 on Kalend's Blog</title><link>https://blog.kalend.top/tags/%E9%81%BF%E5%9D%91%E6%8C%87%E5%8D%97/</link><description>Recent content in 避坑指南 on Kalend's Blog</description><generator>Hugo -- gohugo.io</generator><language>zh</language><lastBuildDate>Wed, 20 May 2026 00:00:00 +0800</lastBuildDate><atom:link href="https://blog.kalend.top/tags/%E9%81%BF%E5%9D%91%E6%8C%87%E5%8D%97/index.xml" rel="self" type="application/rss+xml"/><item><title>踩过的坑全给你：Blog Agent 最佳实践</title><link>https://blog.kalend.top/2026/05/20/multi-agent-pipeline-part4.html/</link><pubDate>Wed, 20 May 2026 00:00:00 +0800</pubDate><guid>https://blog.kalend.top/2026/05/20/multi-agent-pipeline-part4.html/</guid><description>
 &lt;blockquote&gt;
 &lt;p&gt;跟着前三篇搭完 Pipeline，满怀信心跑了一次——然后各种炸。这篇文章是我踩了 50+ 个坑之后，精选出 12 个最致命的。&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;p&gt;多Agent协作系列 第4篇/共4篇（收尾篇） | 避坑指南 | 约2800字 | 作者：varkm&lt;/p&gt;
&lt;h2 id="先说结论"&gt;先说结论
&lt;/h2&gt;&lt;p&gt;踩了 50 多个坑，80% 集中在五个环节。&lt;/p&gt;
&lt;p&gt;我把最致命的 12 个挑出来，按&amp;quot;写→排→配→协→省&amp;quot;五个阶段给你。&lt;/p&gt;
&lt;p&gt;每个坑都附具体命令和代码。&lt;/p&gt;
&lt;p&gt;不是&amp;quot;建议你检查一下&amp;quot;，是&amp;quot;复制这条命令就能验证&amp;quot;。&lt;/p&gt;
&lt;h2 id="一写作篇agent-写的东西能看吗"&gt;一、写作篇：Agent 写的东西能看吗
&lt;/h2&gt;&lt;p&gt;内容质量不是模型能力问题，是验证流程问题。&lt;/p&gt;
&lt;p&gt;Writer 写什么不重要，Reviewer 能拦住什么才重要。&lt;/p&gt;
&lt;h3 id="坑1子代理编造不存在的配置键名"&gt;坑1：子代理编造不存在的配置键名
&lt;/h3&gt;&lt;p&gt;这是最致命的一个坑，没有之一。&lt;/p&gt;
&lt;p&gt;子代理会&amp;quot;幻觉&amp;quot;出看似合理的配置键名。&lt;/p&gt;
&lt;p&gt;比如 &lt;code&gt;tool_circuit_breaker&lt;/code&gt;，听起来很专业对吧？&lt;/p&gt;
&lt;p&gt;源码里根本没有这个键。正确的叫 &lt;code&gt;tool_loop_guardrails&lt;/code&gt;。&lt;/p&gt;
&lt;p&gt;读者拿去配，白配。文章发出去，评论区翻车。&lt;/p&gt;
&lt;p&gt;类似的情况还有：&lt;code&gt;busy_input_mode&lt;/code&gt; 实际叫 &lt;code&gt;display.busy_input_mode&lt;/code&gt;。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;prompt_cache_ttl&lt;/code&gt; 实际叫 &lt;code&gt;prompt_caching.cache_ttl&lt;/code&gt;。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;验证方法——每个键名必须过这关：&lt;/strong&gt;&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;grep -rn &lt;span class="s2"&gt;&amp;#34;键名&amp;#34;&lt;/span&gt; hermes_cli/config.py
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;不存在就不要写，哪怕 AI 信誓旦旦说&amp;quot;我确认过&amp;quot;。&lt;/p&gt;
&lt;p&gt;这条规则我写进了 Reviewer 的检查清单，至今拦住了 20+ 次编造。&lt;/p&gt;
&lt;h3 id="坑2ai-味套话满天飞"&gt;坑2：AI 味套话满天飞
&lt;/h3&gt;&lt;p&gt;&amp;ldquo;值得注意的是&amp;rdquo;、&amp;ldquo;总的来说&amp;rdquo;、&amp;ldquo;首先…其次…最后&amp;rdquo;。&lt;/p&gt;
&lt;p&gt;这些话一出现，读者秒懂：AI 写的。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;解法：&lt;/strong&gt; 把 AI 味关键词清单写进 Reviewer 的规则文件。&lt;/p&gt;
&lt;p&gt;逐段扫描，强制替换为自然过渡。&lt;/p&gt;
&lt;p&gt;不是零容忍——允许 1-2 处漏网，但多了必须打回重写。&lt;/p&gt;
&lt;p&gt;我维护了一份清单，大概 15 个高频 AI 味词组。&lt;/p&gt;
&lt;p&gt;每次审校先跑一遍关键词扫描，比人工逐段看效率高 10 倍。&lt;/p&gt;
&lt;h3 id="坑3评测文事实核查翻车"&gt;坑3：评测文事实核查翻车
&lt;/h3&gt;&lt;p&gt;&amp;ldquo;发布不到一个月&amp;rdquo;——实际仓库已创建 3 个月。&lt;/p&gt;
&lt;p&gt;&amp;ldquo;不支持 Docker&amp;rdquo;——仓库里 Dockerfile 就在根目录。&lt;/p&gt;
&lt;p&gt;&amp;ldquo;我两个都在用&amp;rdquo;——说实话，根本没用过第二个。&lt;/p&gt;
&lt;p&gt;这条最危险，因为&lt;strong&gt;读者会去验证&lt;/strong&gt;。一旦翻车，信任归零。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;核心原则：&lt;/strong&gt; 每一条事实声明都必须验证。&lt;/p&gt;
&lt;p&gt;星数看 GitHub API，技术栈看源码，体验只写真话。&lt;/p&gt;
&lt;p&gt;验证命令：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;curl -s https://api.github.com/repos/owner/repo &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;|&lt;/span&gt; jq &lt;span class="s1"&gt;&amp;#39;{stars: .stargazers_count, created: .created_at}&amp;#39;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;版本追溯三步法：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;git log --oneline --all --grep&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;功能名&amp;#34;&lt;/span&gt; &lt;span class="p"&gt;|&lt;/span&gt; head -5
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;git tag --contains &amp;lt;commit_hash&amp;gt; &lt;span class="p"&gt;|&lt;/span&gt; head -3
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;git show --no-patch --format&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;%H %ci %s&amp;#34;&lt;/span&gt; &amp;lt;commit_hash&amp;gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;
 &lt;blockquote&gt;
 &lt;p&gt;写作篇一行检查：&lt;code&gt;grep -rn &amp;quot;配置键名&amp;quot; config.py&lt;/code&gt;&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;h2 id="二排版篇微信客户端是最大的敌人"&gt;二、排版篇：微信客户端是最大的敌人
&lt;/h2&gt;&lt;p&gt;微信渲染引擎会做你意想不到的事。&lt;/p&gt;
&lt;p&gt;所有样式必须 inline，微信会剥离 &lt;code&gt;&amp;lt;style&amp;gt;&lt;/code&gt; 和 &lt;code&gt;class&lt;/code&gt;。&lt;/p&gt;
&lt;p&gt;这是排版篇的第一条铁律，后面所有坑都跟它有关。&lt;/p&gt;
&lt;h3 id="坑4列表标签全线崩溃"&gt;坑4：列表标签全线崩溃
&lt;/h3&gt;&lt;p&gt;&lt;code&gt;&amp;lt;ul&amp;gt;&lt;/code&gt;、&lt;code&gt;&amp;lt;ol&amp;gt;&lt;/code&gt;、&lt;code&gt;&amp;lt;li&amp;gt;&lt;/code&gt;，三个标签在微信里有三个独立 bug。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;&amp;lt;ol&amp;gt;&lt;/code&gt; 编号跨板块连续计数：第一个列表从 1 开始没问题。&lt;/p&gt;
&lt;p&gt;第二个列表不从 1 开始，接着上一个的编号往下数。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;&amp;lt;ul&amp;gt;&lt;/code&gt; 加手动 bullet 产生双圆点，一行出现两个点。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;&amp;lt;li&amp;gt;&lt;/code&gt; 的 margin 产生空行，每个 item 变成空行 + 内容两行。&lt;/p&gt;
&lt;p&gt;我在这三个标签上各踩了一轮，前后折腾了两天。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;终极方案：&lt;/strong&gt; 全部不要用。&lt;/p&gt;
&lt;p&gt;所有列表统一用 &lt;code&gt;◆&lt;/code&gt; 替代：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-html" data-lang="html"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;p&lt;/span&gt; &lt;span class="na"&gt;style&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;&amp;#34;margin:4px 0;line-height:1.8;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="s"&gt;padding-left:14px;&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;◆ 列表内容&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;p&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;简单、稳定、不炸。这是 3 轮踩坑之后的终极结论。&lt;/p&gt;
&lt;h3 id="坑5代码块黑底黑字"&gt;坑5：代码块黑底黑字
&lt;/h3&gt;&lt;p&gt;微信会剥离 &lt;code&gt;&amp;lt;pre&amp;gt;&lt;/code&gt; 标签的 &lt;code&gt;color&lt;/code&gt; 样式，只剩 &lt;code&gt;background&lt;/code&gt;。&lt;/p&gt;
&lt;p&gt;黑色背景 + 黑色文字 = 完全看不了。&lt;/p&gt;
&lt;p&gt;读者截图问我&amp;quot;代码块怎么什么都没有&amp;quot;。&lt;/p&gt;
&lt;p&gt;我才知道这个坑——在电脑浏览器里是正常的。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;解法：&lt;/strong&gt; 永远不要用深色代码块背景。&lt;/p&gt;
&lt;p&gt;浅色方案用 &lt;code&gt;&amp;lt;section&amp;gt;&lt;/code&gt; 包裹：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-html" data-lang="html"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;section&lt;/span&gt; &lt;span class="na"&gt;style&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;&amp;#34;background:#f6f8fa;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="s"&gt;border-radius:6px;padding:14px;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="s"&gt;border:1px solid #e1e4e8;&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;pre&lt;/span&gt; &lt;span class="na"&gt;style&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;&amp;#34;margin:0;color:#24292e;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="s"&gt;font-size:14px;&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;代码内容&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;pre&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;section&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;关键是用 &lt;code&gt;&amp;lt;section&amp;gt;&lt;/code&gt; 而不是直接靠 &lt;code&gt;&amp;lt;pre&amp;gt;&lt;/code&gt; 的样式。&lt;/p&gt;
&lt;p&gt;深色方案也可以，但同样必须用 &lt;code&gt;&amp;lt;section&amp;gt;&lt;/code&gt; + &lt;code&gt;&amp;lt;span&amp;gt;&lt;/code&gt; 做语法高亮。&lt;/p&gt;
&lt;h3 id="坑6封面图中文变方格"&gt;坑6：封面图中文变方格
&lt;/h3&gt;&lt;p&gt;Pillow 默认字体（DejaVu）不支持中文。&lt;/p&gt;
&lt;p&gt;所有中文字符渲染成方格/空白。&lt;/p&gt;
&lt;p&gt;发出去才知道——封面上的标题全是空白方块。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;解法：&lt;/strong&gt; 必须用系统 CJK 字体，且 &lt;code&gt;.ttc&lt;/code&gt; 文件要加 &lt;code&gt;index=0&lt;/code&gt;：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-python" data-lang="python"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="kn"&gt;from&lt;/span&gt; &lt;span class="nn"&gt;PIL&lt;/span&gt; &lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="n"&gt;ImageFont&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;font&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;ImageFont&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;truetype&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;/usr/share/fonts/opentype/noto/&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="s2"&gt;&amp;#34;NotoSansCJK-Bold.ttc&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="mi"&gt;36&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;index&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;code&gt;.ttc&lt;/code&gt; 是字体集合文件，不指定 &lt;code&gt;index&lt;/code&gt; 可能加载到错误字体。&lt;/p&gt;
&lt;p&gt;这个参数踩了我半小时才找到原因。&lt;/p&gt;

 &lt;blockquote&gt;
 &lt;p&gt;排版篇一行检查：&lt;code&gt;grep -n '&amp;lt;ul&amp;gt;\|&amp;lt;ol&amp;gt;\|&amp;lt;li&amp;gt;' article.html&lt;/code&gt;&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;h2 id="三配置篇80-的崩溃来自两个默认值"&gt;三、配置篇：80% 的崩溃来自两个默认值
&lt;/h2&gt;&lt;p&gt;不是功能不好用，是默认配置没改。&lt;/p&gt;
&lt;p&gt;改两个配置，解决 80% 的 Pipeline 崩溃。&lt;/p&gt;
&lt;h3 id="坑7max_tokens-太小导致截断"&gt;坑7：max_tokens 太小导致截断
&lt;/h3&gt;&lt;p&gt;默认 &lt;code&gt;max_tokens&lt;/code&gt; 只有 4096。&lt;/p&gt;
&lt;p&gt;一篇 2000 字的文章大概需要 8000-12000 token。&lt;/p&gt;
&lt;p&gt;超了直接截断，Agent crash，日志显示：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-gdscript3" data-lang="gdscript3"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;Response&lt;/span&gt; &lt;span class="n"&gt;truncated&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;finish_reason&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s1"&gt;&amp;#39;length&amp;#39;&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;refusing&lt;/span&gt; &lt;span class="n"&gt;to&lt;/span&gt; &lt;span class="n"&gt;execute&lt;/span&gt; &lt;span class="n"&gt;incomplete&lt;/span&gt; &lt;span class="k"&gt;tool&lt;/span&gt; &lt;span class="n"&gt;arguments&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;解法：&lt;/strong&gt; Profile 配置里改成 32768 或更大：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-yaml" data-lang="yaml"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="nt"&gt;model&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nt"&gt;max_tokens&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="m"&gt;32768&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;Worker 自己改不了这个值。&lt;/p&gt;
&lt;p&gt;必须由 Orchestrator 在 Profile 配置文件里提前设好。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;算笔账：&lt;/strong&gt; 一次跑完 vs 截断重跑。&lt;/p&gt;
&lt;p&gt;截断一次 = 浪费已消耗的 token + 重新跑一遍完整流程。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;max_tokens&lt;/code&gt; 调大，单次不会多花，但省掉了重试的浪费。&lt;/p&gt;
&lt;h3 id="坑8skill-文件没复制到-profile-目录"&gt;坑8：Skill 文件没复制到 Profile 目录
&lt;/h3&gt;&lt;p&gt;全局 skill 目录和 Profile 独立目录是两套。&lt;/p&gt;
&lt;p&gt;Profile 看不到全局目录里的 skill，必须手动复制。&lt;/p&gt;
&lt;p&gt;报错信息：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-fallback" data-lang="fallback"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;Error: Unknown skill(s): article-review
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;明明装了，为什么找不到？因为装错地方了。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;解法：&lt;/strong&gt; Orchestrator dispatch 前检查并复制：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;cp -r ~/.hermes/skills/devops/article-review &lt;span class="se"&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; ~/.hermes/profiles/blog-writer/skills/devops/
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;路径规则：全局 &lt;code&gt;~/.hermes/skills/&lt;/code&gt; ≠ Profile 独立目录。&lt;/p&gt;
&lt;p&gt;我第一次遇到这个报错时，反复重装了 3 遍 skill 才反应过来。&lt;/p&gt;
&lt;p&gt;装的全是全局目录，Profile 根本看不到。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;这两个配置改完，80% 的 Pipeline 崩溃直接消失。&lt;/strong&gt;&lt;/p&gt;

 &lt;blockquote&gt;
 &lt;p&gt;配置篇一行检查：&lt;code&gt;grep &amp;quot;max_tokens&amp;quot; ~/.hermes/profiles/你的profile/config.yaml&lt;/code&gt;&lt;/p&gt;

 &lt;/blockquote&gt;
&lt;h2 id="四协作篇agent-编排的三个反模式"&gt;四、协作篇：Agent 编排的三个反模式
&lt;/h2&gt;&lt;p&gt;Pipeline 不是流程负担，是质量保险。&lt;/p&gt;
&lt;p&gt;跳过的每一步，都会在下游加倍还回来。&lt;/p&gt;
&lt;h3 id="坑9跳过-pipeline-裸写"&gt;坑9：跳过 Pipeline 裸写
&lt;/h3&gt;&lt;p&gt;手动 &lt;code&gt;delegate_task&lt;/code&gt; 直接让一个 Agent 写文章，没有 Reviewer。&lt;/p&gt;
&lt;p&gt;看起来快，实际上：&lt;/p&gt;
&lt;table&gt;
 &lt;thead&gt;
 &lt;tr&gt;
 &lt;th&gt;对比项&lt;/th&gt;
 &lt;th&gt;Pipeline&lt;/th&gt;
 &lt;th&gt;裸写&lt;/th&gt;
 &lt;/tr&gt;
 &lt;/thead&gt;
 &lt;tbody&gt;
 &lt;tr&gt;
 &lt;td&gt;Reviewer 把关&lt;/td&gt;
 &lt;td&gt;有&lt;/td&gt;
 &lt;td&gt;无&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;审计链路&lt;/td&gt;
 &lt;td&gt;有&lt;/td&gt;
 &lt;td&gt;无&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;返工次数&lt;/td&gt;
 &lt;td&gt;1-2 次&lt;/td&gt;
 &lt;td&gt;3-5 次&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;总耗时&lt;/td&gt;
 &lt;td&gt;16 分钟&lt;/td&gt;
 &lt;td&gt;30+ 分钟&lt;/td&gt;
 &lt;/tr&gt;
 &lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;裸写最大的问题不是质量差。&lt;/p&gt;
&lt;p&gt;是&lt;strong&gt;你不知道质量差&lt;/strong&gt;——没有 Reviewer 告诉你哪里有问题。&lt;/p&gt;
&lt;p&gt;等读者反馈，已经晚了。&lt;/p&gt;
&lt;p&gt;我写过一篇裸写的文章，3 个配置键名编造，2 处 AI 味套话。&lt;/p&gt;
&lt;p&gt;没有 Reviewer 拦，全发出去了。后来评论区被指出才改。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;强制规则：&lt;/strong&gt; 走完整 Kanban Pipeline，无例外。&lt;/p&gt;
&lt;p&gt;流程：Writer → Reviewer → Creator → Reviewer → 发布。&lt;/p&gt;
&lt;h3 id="坑10task_id-幻觉编造"&gt;坑10：task_id 幻觉编造
&lt;/h3&gt;&lt;p&gt;&lt;code&gt;kanban_complete&lt;/code&gt; 时传入编造的 task_id。&lt;/p&gt;
&lt;p&gt;kernel 验证不通过，直接报错：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-fallback" data-lang="fallback"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;phantom id blocks the completion
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;&lt;strong&gt;核心：&lt;/strong&gt; task_id 只能来自 &lt;code&gt;kanban_create&lt;/code&gt; 的返回值。&lt;/p&gt;
&lt;p&gt;不要从文字描述里&amp;quot;编&amp;quot;，不要从上一轮的上下文里&amp;quot;猜&amp;quot;。&lt;/p&gt;
&lt;p&gt;正确写法——先捕获返回值，再传入：&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt;1
&lt;/span&gt;&lt;span class="lnt"&gt;2
&lt;/span&gt;&lt;span class="lnt"&gt;3
&lt;/span&gt;&lt;span class="lnt"&gt;4
&lt;/span&gt;&lt;span class="lnt"&gt;5
&lt;/span&gt;&lt;span class="lnt"&gt;6
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-python" data-lang="python"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;card&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;kanban_create&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;title&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;审校文章&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;assignee&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;reviewer&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;kanban_complete&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;created_cards&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;card&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="s2"&gt;&amp;#34;task_id&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;]]&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;错误写法：从摘要中看到 &amp;ldquo;t_deadbeef&amp;rdquo; 就传进去。&lt;/p&gt;
&lt;p&gt;kernel 会验证每个 id 是否真实存在，幻编的 id 100% 被拦截。&lt;/p&gt;
&lt;h3 id="坑11reviewer-模型比-writer-弱"&gt;坑11：Reviewer 模型比 Writer 弱
&lt;/h3&gt;&lt;p&gt;Writer 用最强模型写，Reviewer 用弱模型审。&lt;/p&gt;
&lt;p&gt;结果：审校形同虚设，该拦的拦不住。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;规则：&lt;/strong&gt; 审核模型必须 ≥ 写作模型。&lt;/p&gt;
&lt;table&gt;
 &lt;thead&gt;
 &lt;tr&gt;
 &lt;th&gt;角色&lt;/th&gt;
 &lt;th&gt;推荐模型&lt;/th&gt;
 &lt;th&gt;定位&lt;/th&gt;
 &lt;/tr&gt;
 &lt;/thead&gt;
 &lt;tbody&gt;
 &lt;tr&gt;
 &lt;td&gt;Writer&lt;/td&gt;
 &lt;td&gt;glm-4.7&lt;/td&gt;
 &lt;td&gt;性价比写稿&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Creator&lt;/td&gt;
 &lt;td&gt;glm-4.7&lt;/td&gt;
 &lt;td&gt;排版生成&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Reviewer&lt;/td&gt;
 &lt;td&gt;glm-5.1&lt;/td&gt;
 &lt;td&gt;强模型把关&lt;/td&gt;
 &lt;/tr&gt;
 &lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;贵的模型只干贵的事——审核就是最该花 token 的环节。&lt;/p&gt;
&lt;h2 id="五成本篇怎么让-agent-省着花"&gt;五、成本篇：怎么让 Agent 省着花
&lt;/h2&gt;&lt;p&gt;不是不能用贵模型，是别在不需要的地方用。&lt;/p&gt;
&lt;h3 id="坑12pipeline-被反复跳过"&gt;坑12：Pipeline 被反复&amp;quot;跳过&amp;quot;
&lt;/h3&gt;&lt;p&gt;完整 Pipeline 6 步全 PASS 只需 16 分钟。&lt;/p&gt;
&lt;p&gt;但经常有人觉得&amp;quot;Pipeline 慢&amp;quot;，手动跳过。&lt;/p&gt;
&lt;p&gt;跳过的后果：质量不过关 → 返工 → 再跑一遍 → 总耗时翻倍。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;不要跳。&lt;/strong&gt; 16 分钟换一次通过，比跳过之后返工 30 分钟划算。&lt;/p&gt;
&lt;h3 id="分层用模型才是真省钱"&gt;分层用模型才是真省钱
&lt;/h3&gt;&lt;p&gt;全文用一个模型 = 全程用最贵的模型 = 浪费。&lt;/p&gt;
&lt;p&gt;写作用性价比模型，快且便宜。&lt;/p&gt;
&lt;p&gt;排版用同样的性价比模型。&lt;/p&gt;
&lt;p&gt;审核用强模型，只审核一次。&lt;/p&gt;
&lt;p&gt;贵模型用得少，但每次用在关键位置。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;max_tokens&lt;/code&gt; 调大 + 模型分层，总成本反而比&amp;quot;省钱方案&amp;quot;更低。&lt;/p&gt;
&lt;p&gt;具体算一下：Writer 跑 5 分钟用 glm-4.7，Reviewer 跑 2 分钟用 glm-5.1。&lt;/p&gt;
&lt;p&gt;比全程用 glm-5.1 省 60% 以上 token。&lt;/p&gt;
&lt;p&gt;该省省，该花花——审核环节绝不省钱。&lt;/p&gt;
&lt;h2 id="系列-4-篇收尾"&gt;系列 4 篇收尾
&lt;/h2&gt;&lt;p&gt;回顾整个多Agent协作系列：&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;第 1 篇&lt;/strong&gt; 讲了 Kanban + Profile，让 Agent 有了分工和身份。&lt;/p&gt;
&lt;p&gt;Kanban 是任务看板，Profile 是 Agent 的角色配置。&lt;/p&gt;
&lt;p&gt;两者结合，Agent 从&amp;quot;什么都干&amp;quot;变成&amp;quot;各司其职&amp;quot;。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;第 2 篇&lt;/strong&gt; 搭建了 Blog Writer Agent，7 步从零到能写能部署。&lt;/p&gt;
&lt;p&gt;从安装框架到写第一篇文章，全程可跟着操作。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;第 3 篇&lt;/strong&gt; 组建了完整 Pipeline，多 Agent 协作链路跑通。&lt;/p&gt;
&lt;p&gt;Writer 写稿 → Reviewer 审校 → Creator 排版 → 发布。&lt;/p&gt;
&lt;p&gt;6 步全 PASS 只需 16 分钟。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;第 4 篇&lt;/strong&gt;（这篇）补上了最后一环：搭完怎么不炸。&lt;/p&gt;
&lt;p&gt;12 个坑，5 个阶段，每个都有具体命令和代码。&lt;/p&gt;
&lt;p&gt;收藏这篇，每次跑 Pipeline 之前扫一遍检查清单。&lt;/p&gt;
&lt;p&gt;四篇读完，你就有了一套完整的 Agent 博客系统。&lt;/p&gt;
&lt;p&gt;从搭建到协作到避坑，该踩的坑我都替你踩了。&lt;/p&gt;
&lt;section style="margin:20px 0;padding:16px 20px;background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:8px;text-align:center;"&gt;
&lt;p style="margin:0 0 8px 0;color:#fff;font-size:16px;font-weight:bold;line-height:1.6;"&gt;关注 varkm，一起学习，一起成长&lt;/p&gt;
&lt;p style="margin:0;color:rgba(255,255,255,0.85);font-size:13px;line-height:1.6;"&gt;多Agent协作系列完更，回复【agent】获取完整检查清单和 Profile 配置模板&lt;/p&gt;
&lt;/section&gt;</description></item></channel></rss>