<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>AI Agent on Kalend's Blog</title><link>https://blog.kalend.top/categories/ai-agent/</link><description>Recent content in AI Agent 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/categories/ai-agent/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><item><title>Hermes vs OpenClaw对比：终端派 Hermes Agent 的选择</title><link>https://blog.kalend.top/2026/05/18/hermes-vs-openclaw.html/</link><pubDate>Mon, 18 May 2026 22:00:00 +0800</pubDate><guid>https://blog.kalend.top/2026/05/18/hermes-vs-openclaw.html/</guid><description>&lt;h2 id="结论先说这不是竞品"&gt;结论先说：这不是竞品
&lt;/h2&gt;&lt;p&gt;这两个项目根本不在一条赛道上。&lt;/p&gt;
&lt;p&gt;OpenClaw（小龙虾🦞）想做的是「全平台个人AI助手」——像Siri一样渗透到你生活的每个角落，微信、WhatsApp、Telegram、macOS、iOS、Android，它都能接。你想用什么渠道就跟它说什么，它就回你在哪儿。&lt;/p&gt;
&lt;p&gt;Hermes Agent 做的是「终端派 Hermes Agent 框架」——给开发者和技术用户的一把瑞士军刀。Kanban任务板、多Agent编排、技能系统、记忆宫殿，全是围绕「如何把复杂任务拆解、分配、执行」设计的。&lt;/p&gt;
&lt;p&gt;如果你想找个好用的个人助手，选 OpenClaw；如果你想搭个能自动跑活的Agent系统，选 Hermes。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="表格对比一眼看懂差异"&gt;表格对比：一眼看懂差异
&lt;/h2&gt;&lt;table&gt;
 &lt;thead&gt;
 &lt;tr&gt;
 &lt;th&gt;维度&lt;/th&gt;
 &lt;th&gt;OpenClaw（小龙虾）&lt;/th&gt;
 &lt;th&gt;Hermes Agent&lt;/th&gt;
 &lt;/tr&gt;
 &lt;/thead&gt;
 &lt;tbody&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;定位&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;个人AI助手&lt;/td&gt;
 &lt;td&gt;终端Hermes Agent框架&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;GitHub Stars&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;372,888&lt;/td&gt;
 &lt;td&gt;较小众&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;语言&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;TypeScript&lt;/td&gt;
 &lt;td&gt;Python + TypeScript&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;渠道覆盖&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;20+（微信、WhatsApp、Telegram、Slack、Discord、QQ、iMessage、macOS、iOS、Android等）&lt;/td&gt;
 &lt;td&gt;微信、飞书、Telegram、Discord&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;上手门槛&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;一条命令 &lt;code&gt;openclaw onboard&lt;/code&gt; 自动配置&lt;/td&gt;
 &lt;td&gt;需要理解Kanban、Profile、Skill概念&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;多Agent能力&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;Multi-agent routing（按渠道/账户隔离）&lt;/td&gt;
 &lt;td&gt;Kanban任务板 + Subagent委托（可视化编排）&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;记忆系统&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;基于会话&lt;/td&gt;
 &lt;td&gt;MemPalace（四级回忆链：热记忆→MemPalace→session_search→外部知识库）&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;定时任务&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;Cron jobs&lt;/td&gt;
 &lt;td&gt;内置Cronjob工具（带keep-alive、context注入）&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;技能生态&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;ClawHub（5400+ skills）&lt;/td&gt;
 &lt;td&gt;自建Skill系统（轻量级，易定制）&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;部署方式&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;Gateway + 多渠道inbox，支持Node 24/22.19+&lt;/td&gt;
 &lt;td&gt;100%本地部署，零第三方依赖&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;安全模型&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;Sandbox模式（Docker/SSH/OpenShell）&lt;/td&gt;
 &lt;td&gt;可选Bash/SSH后端&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;特色功能&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;Voice Wake、Live Canvas、macOS/iOS/Android原生App&lt;/td&gt;
 &lt;td&gt;Kanban可视化、Profile隔离、技能热加载&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;&lt;strong&gt;适合人群&lt;/strong&gt;&lt;/td&gt;
 &lt;td&gt;想要「好用的助手」的普通用户&lt;/td&gt;
 &lt;td&gt;开发者、技术用户、需要自动化工作流的人&lt;/td&gt;
 &lt;/tr&gt;
 &lt;/tbody&gt;
&lt;/table&gt;
&lt;hr&gt;
&lt;h2 id="渠道覆盖openclaw-完胜"&gt;渠道覆盖：OpenClaw 完胜
&lt;/h2&gt;&lt;p&gt;OpenClaw 支持的渠道列表长得吓人：WhatsApp、Telegram、Slack、Discord、Google Chat、Signal、iMessage、IRC、Microsoft Teams、Matrix、Feishu、LINE、Mattermost、Nextcloud Talk、Nostr、Synology Chat、Tlon、Twitch、Zalo、Zalo Personal、WeChat、QQ、WebChat、macOS、iOS/Android。&lt;/p&gt;
&lt;p&gt;你想在哪个平台跟它聊天，它就在那儿等你。而且它不是简单的「转发消息」，每个渠道都有深度集成——比如 macOS 有 Live Canvas（可视化工作台）、iOS/Android 有 Voice Wake（语音唤醒）、桌面端有原生 App。&lt;/p&gt;
&lt;p&gt;Hermes 只支持四个渠道：微信、飞书、Telegram、Discord。但对我来说够用了——我的主要沟通场景就是微信，偶尔在 Discord 跟技术社区交流。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="上手门槛openclaw-友好hermes-需要理解成本"&gt;上手门槛：OpenClaw 友好，Hermes 需要理解成本
&lt;/h2&gt;&lt;p&gt;OpenClaw 的入门体验堪称教科书级别：&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;npm install -g openclaw@latest
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;openclaw onboard --install-daemon
&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;onboard&lt;/code&gt; 命令会引导你一步步配置 Gateway、Workspace、Channels、Skills，像安装软件一样。而且它有 macOS 菜单栏 App、iOS/Android Node，可视化程度很高。&lt;/p&gt;
&lt;p&gt;Hermes 的学习曲线要陡峭一些。你需要理解三个核心概念：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Kanban&lt;/strong&gt;：任务板，用来管理和跟踪任务&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Profile&lt;/strong&gt;：Agent 配置文件，不同的 Profile 有不同的工具集和能力&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Skill&lt;/strong&gt;：技能包，可复用的任务流程&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;这不是「安装就能用」，而是「学习后才能发挥威力」的工具。但一旦你理解了这套系统，它的灵活性远超 OpenClaw。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="多agent能力设计哲学差异"&gt;多Agent能力：设计哲学差异
&lt;/h2&gt;&lt;p&gt;两者都支持多 Agent，但思路完全不同。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;OpenClaw&lt;/strong&gt; 采用「路由隔离」模式：你可以为不同的渠道、账户、Peer 配置独立的 Agent。比如你的微信发给 Agent A，WhatsApp 发给 Agent B，Telegram 的某个群发给 Agent C。每个 Agent 有自己的 Workspace、Session、Tool 配置。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Hermes&lt;/strong&gt; 采用「任务板编排」模式：所有任务在 Kanban 上统一管理，通过 &lt;code&gt;parents&lt;/code&gt; 字段表达依赖关系。你可以把一个大任务拆解成多个子任务，每个子任务分配给不同的 Profile（比如 &lt;code&gt;researcher&lt;/code&gt; 做调研、&lt;code&gt;writer&lt;/code&gt; 写文章、&lt;code&gt;reviewer&lt;/code&gt; 审核）。当所有父任务完成，子任务自动从 &lt;code&gt;todo&lt;/code&gt; 提升到 &lt;code&gt;ready&lt;/code&gt;。&lt;/p&gt;
&lt;p&gt;OpenClaw 更像「多租户隔离」，Hermes 更像「项目化管理」。前者适合个人多场景使用，后者适合复杂工作流自动化。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="记忆系统mempalace-是杀手级特性"&gt;记忆系统：MemPalace 是杀手级特性
&lt;/h2&gt;&lt;p&gt;Hermes 的 MemPalace 是我最喜欢的功能。它不是简单的「存储对话历史」，而是四级回忆链：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;热记忆&lt;/strong&gt;（~2200字符）：高频使用的用户偏好、行为规则、环境配置&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;MemPalace&lt;/strong&gt;：长期知识库，支持分类存储（drawers + memories）&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Session Search&lt;/strong&gt;：搜索过去会话的总结，快速找回上下文&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;外部知识库&lt;/strong&gt;：通过 IMA 集成，连接你的笔记、知识库、收藏&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;OpenClaw 的记忆系统相对传统，主要是基于会话的短期记忆。它也能记住一些上下文，但没有 MemPalace 这种结构化的知识管理。&lt;/p&gt;
&lt;p&gt;如果你需要 Agent 真正「记住」你的长期偏好和知识，Hermes 的 MemPalace 完胜。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="部署方式100本地-vs-gateway模式"&gt;部署方式：100%本地 vs Gateway模式
&lt;/h2&gt;&lt;p&gt;Hermes 是 100% 本地部署的，零第三方依赖。你只需要一个 Python 环境，就能跑起来。所有数据都在你的机器上，隐私绝对安全。&lt;/p&gt;
&lt;p&gt;OpenClaw 是 Gateway 模式——本地跑一个 Gateway 服务（Node 24/22.19+），然后通过各种渠道接入。它支持 7x24 运行，有专业的 daemon 进程管理。但它需要更多的依赖和配置。&lt;/p&gt;
&lt;p&gt;两种部署方式各有优劣：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Hermes&lt;/strong&gt;：简单、轻量、隐私友好，但需要你自己维护进程&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;OpenClaw&lt;/strong&gt;：专业、稳定、开箱即用，但需要更多资源&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h2 id="生态clawhub-vs-自建技能"&gt;生态：ClawHub vs 自建技能
&lt;/h2&gt;&lt;p&gt;OpenClaw 有 ClawHub 技能市场，5400+ skills，涵盖各种场景。你想干什么基本都有现成的技能包。&lt;/p&gt;
&lt;p&gt;Hermes 的 Skill 系统更轻量级，主要是自建。官方提供了一些通用技能（比如 &lt;code&gt;kanban-worker&lt;/code&gt;、&lt;code&gt;hugo-blog&lt;/code&gt;），但你大部分时间是自己写技能。&lt;/p&gt;
&lt;p&gt;这跟设计哲学有关：OpenClaw 想做「产品」，给你现成的东西用；Hermes 想做「框架」，给你工具自己做。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="选择建议什么人选什么"&gt;选择建议：什么人选什么？
&lt;/h2&gt;&lt;h3 id="选-openclaw如果你"&gt;选 OpenClaw，如果你：
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;想要一个好用的个人AI助手，不想折腾&lt;/li&gt;
&lt;li&gt;需要覆盖多个渠道（尤其是非技术平台）&lt;/li&gt;
&lt;li&gt;喜欢「可视化操作」和「原生 App」的体验&lt;/li&gt;
&lt;li&gt;不介意多装一些依赖，希望开箱即用&lt;/li&gt;
&lt;li&gt;主要场景是「聊聊天、查查信息、简单自动化」&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id="选-hermes如果你"&gt;选 Hermes，如果你：
&lt;/h3&gt;&lt;ol&gt;
&lt;li&gt;是开发者或技术用户，愿意学习新概念&lt;/li&gt;
&lt;li&gt;需要复杂工作流自动化（比如博客写作、代码审查、多Agent协作）&lt;/li&gt;
&lt;li&gt;看重数据隐私，希望 100% 本地部署&lt;/li&gt;
&lt;li&gt;想要灵活定制自己的 Agent 系统&lt;/li&gt;
&lt;li&gt;主要场景是「项目化任务管理」和「深度自动化」&lt;/li&gt;
&lt;/ol&gt;
&lt;hr&gt;
&lt;h2 id="我的选择"&gt;我的选择
&lt;/h2&gt;&lt;p&gt;我两个都用了，但最后选择了 Hermes。&lt;/p&gt;
&lt;p&gt;原因很简单：我是一个技术用户，大部分时间在终端和编辑器里工作。Hermes 的 Kanban、Profile、Skill 这套系统，正好匹配我的工作方式。我可以用 Kanban 管理博客写作计划，用不同的 Profile 处理不同类型的任务，用 Skill 封装可复用的流程。&lt;/p&gt;
&lt;p&gt;OpenClaw 很强大，但它的优势不在我的使用场景里。我不需要在 20 个渠道上跟 AI 聊天，也不需要 Live Canvas 或 Voice Wake。我需要的是能帮我自动化复杂任务、记住我的长期偏好、可灵活定制的工具——这些正是 Hermes 的强项。&lt;/p&gt;
&lt;p&gt;当然，这不代表 OpenClaw 不好。它是一个非常优秀的个人AI助手，GitHub 372,888 stars 说明了一切。只是对我来说，Hermes 更对胃口。&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="后续有没有可能融合"&gt;后续：有没有可能融合？
&lt;/h2&gt;&lt;p&gt;技术上完全可能。Hermes 可以通过 WebSocket 或 CLI 接入 OpenClaw 的 Gateway，享受它的多渠道能力；OpenClaw 也可以借鉴 Hermes 的 Kanban 和 MemPalace，增强任务管理和知识记忆。&lt;/p&gt;
&lt;p&gt;但目前它们确实是两个方向的产品。OpenClaw 追求「覆盖广」和「易用」，Hermes 追求「深度定制」和「专业自动化」。&lt;/p&gt;
&lt;p&gt;没有谁比谁好，只有谁更适合你。&lt;/p&gt;
&lt;hr&gt;
&lt;p&gt;&lt;strong&gt;关注 varkm，一起学习，一起成长&lt;/strong&gt;&lt;/p&gt;</description></item></channel></rss>