Clawdbot 对接 Qwen3-32B 的 Web 网关配置指南
1. 理解整个链路:三步到位,缺一不可
很多初学者失败,不是因为命令写错了,而是没理清'谁在跟谁说话'。我们先用一句话说清核心逻辑:
Clawdbot 本身不直接运行 Qwen3 模型,它只是一个带 UI 的聊天前端;它需要通过 HTTP 请求,把用户输入发给一个符合 OpenAI 兼容 API 规范的服务端;而 Ollama 提供的
/v1/chat/completions接口,正好就是这个服务端——但默认只监听127.0.0.1:11434,Clawdbot 无法直连;因此必须加一层内部代理,把 Clawdbot 发来的请求,原样转发给 Ollama,并把响应原样送回。
这个链路包含三个关键角色,各自职责明确:
- Clawdbot:负责渲染网页、管理会话、收集用户输入、展示回复。它只认一种语言:OpenAI 格式的 JSON API。
- Ollama + Qwen3:32B:负责真正执行推理。启动后默认提供
http://localhost:11434/v1/chat/completions接口,但该地址仅限本机访问,且路径与 OpenAI 标准略有差异(需做轻量适配)。 - 内部代理(核心桥梁):一个极简的 HTTP 转发服务,监听
localhost:18789,接收 Clawdbot 请求,改写 URL 和 Header 后转发给 Ollama,再把 Ollama 响应原样返回。它解决的是网络可达性和协议兼容性两个问题。
三者关系不是并列,而是严格串行:
用户在 Clawdbot 输入 → Clawdbot 发 POST 到 http://localhost:18789/v1/chat/completions → 代理转发到 http://localhost:11434/api/chat → Ollama 返回结果 → 代理转成 OpenAI 格式 → Clawdbot 渲染
只要其中任一环断开,就会出现'页面无反应''Connection refused'或'Invalid response format'等错误。下面我们就按这个顺序,逐个打通。
2. 前置准备:确认基础环境已就绪
别跳过这一步。很多看似奇怪的问题,根源都在环境没校准。
2.1 检查 Ollama 是否正常运行并加载 Qwen3-32B
打开终端,执行:
ollama list
你应该看到类似输出:
NAME ID SIZE MODIFIED qwen3:32b abc123... 22.4 GB 2 hours ago
如果没有,请先拉取模型:
ollama pull qwen3:32b
注意:
qwen3:32b是 Ollama 模型名,对应 Hugging Face 上的Qwen/Qwen3-32B。确保你拉取的是官方镜像,而非社区魔改版。非官方版本可能缺少 thinking mode 支持或 API 字段不兼容。
接着验证 Ollama 服务是否在监听:
curl http://localhost:11434
成功返回{"message":"Ollama is running"}即表示服务正常。
再测试模型能否响应最简请求(不涉及 Clawdbot):
curl -X POST http://localhost:11434/api/chat \
-H "Content-Type: application/json" \
-d '{ "model": "qwen3:32b", "messages": [{"role": "user", "content": "你好"}], "stream": false }'
如果返回包含"message":{"role":"assistant","content":"..."}的 JSON,说明模型推理通路已通。这是后续所有配置的前提。
2.2 获取 Clawdbot 镜像并确认启动方式
你使用的镜像为 Clawdbot 整合版,它已预装 Clawdbot 前端代码和代理服务,但不会自动启动 Ollama——Ollama 必须由你单独安装并运行。
启动 Clawdbot 容器时,务必使用以下命令(关键在端口映射和网络模式):
docker run -d \
--name clawdbot-qwen3 \
--network host \
-p 8080:8080 \
-v $(pwd)/config:/app/config \
your-clawdbot-image-name
--network host:让容器直接使用宿主机网络,避免 Docker 内网与 localhost 隔离导致代理无法访问127.0.0.1:11434-p 8080:8080:将容器内 Web 服务暴露到宿主机 8080 端口,你浏览器访问http://localhost:8080即可-v $(pwd)/config:/app/config:挂载配置目录,便于后续修改代理设置(重点!)
启动后,访问http://localhost:8080,应能看到 Clawdbot 登录页或聊天界面。此时页面仍无法发送消息——因为代理还没指向正确的后端。
3. 核心配置:编写并启用内部代理服务
这才是真正的'临门一脚'。Clawdbot 镜像内置了一个轻量代理(通常基于 Node.js 或 Python Flask),但它的目标地址默认是空的或指向示例模型。你需要手动告诉它:'把请求发给我的 Qwen3'。
3.1 定位并编辑代理配置文件
进入你挂载的配置目录(即上一步-v指定的$(pwd)/config):
cd $(pwd)
ls -la
你会看到类似文件:
proxy.config.json或backend.json(代理服务的配置)clawdbot.config.json(前端 UI 配置)
打开proxy.config.json(若不存在,新建一个),填入以下内容:
{
"target": "http://localhost:11434",
"changeOrigin": true,
"rewrite": { "^/v1": "/api" },
"headers": { "Content-Type": "application/json" }
}
关键点解析:
"target": "http://localhost:11434":明确告诉代理,所有请求最终发往 Ollama 默认地址"rewrite": {"^/v1": "/api"}:Clawdbot 前端发的是/v1/chat/completions,Ollama 需要的是/api/chat,此规则自动将路径前缀/v1替换成/api"changeOrigin": true:允许跨域(虽在 host 网络下非必需,但兼容性更好)- 无需添加认证头(Ollama 本地 API 默认无鉴权)
保存文件。代理服务会在检测到配置变更后自动重载(如未自动重载,重启容器)。
3.2 验证代理是否工作
在终端执行:
curl -X POST http://localhost:18789/v1/chat/completions \
-H "Content-Type: application/json" \
-d '{ "model": "qwen3:32b", "messages": [{"role": "user", "content": "用一句话介绍 Qwen3 的特点"}], "stream": false }'
成功表现:返回结构完整的 JSON,choices[0].message.content中包含 Qwen3 生成的回答,且无error字段。
❌ 失败常见原因:
- 返回
Connection refused:代理服务未启动,或端口18789未监听(检查容器日志:docker logs clawdbot-qwen3 | grep -i proxy) - 返回
404 Not Found:rewrite规则未生效,检查代理是否读取了新配置 - 返回
500 Internal Error:Ollama 地址错误,或模型名qwen3:32b拼写有误
一旦此命令返回有效响应,说明代理链路已通——Clawdbot 只需指向这个地址即可。
4. Clawdbot 前端配置:告诉 UI'去哪发请求'
Clawdbot 前端需要知道 API 服务的地址。这个地址不是 Ollama 的11434,也不是代理的18789,而是Clawdbot 自身容器内视角的地址。
由于我们用了--network host,容器内localhost即指宿主机,因此前端应配置为:
http://localhost:18789
4.1 修改 Clawdbot 的 API Base URL
编辑挂载目录下的clawdbot.config.json(或类似名称,如config.json):
{
"apiBaseUrl": "http://localhost:18789",
"defaultModel": "qwen3:32b",
"enableThinkingMode": true
}
"apiBaseUrl":必须设为http://localhost:18789,这是 Clawdbot 前端发起请求的目标"defaultModel":与 Ollama 中模型名严格一致,大小写、冒号、版本号都不能错"enableThinkingMode":设为true可启用 Qwen3 的深度推理模式(需模型支持),设为false则走极速响应模式
小技巧:Clawdbot 通常支持在聊天界面右上角'设置'中动态修改 API 地址,无需改文件。但首次配置建议直接改配置文件,避免缓存干扰。
4.2 重启 Clawdbot 使配置生效
docker restart clawdbot-qwen3
等待 10 秒,刷新http://localhost:8080。此时界面应已加载完成,输入任意问题(如'今天天气怎么样?'),点击发送。
正常表现:输入框下方出现'正在思考…'提示,几秒后显示 Qwen3 生成的回复。
进阶验证:打开浏览器开发者工具(F12)→ Network 标签页,发送消息,观察名为chat/completions的请求,其Status应为200,Preview中可见完整 JSON 响应。
5. 排查常见问题:比教程更实用的实战经验
配置完成后,90% 的用户能一次成功。剩下 10% 的问题,基本集中在这几个点:
5.1 问题:Clawdbot 显示'Network Error'或'Request failed'
检查点 2:Ollama 模型未加载
ollama list中qwen3:32b状态是否为?或空白?执行ollama ps看模型是否在运行中。若未运行,手动加载:
ollama run qwen3:32b
(注意:此命令会进入交互式会话,按Ctrl+C退出即可,模型仍在后台运行)
检查点 1:端口冲突
18789端口是否被其他程序占用?执行:
lsof -i :18789 # macOS/Linux
netstat -ano | findstr :18789 # Windows
若有占用,修改proxy.config.json中的监听端口(如改为18790),并同步更新clawdbot.config.json中的apiBaseUrl。
5.2 问题:消息发送后无响应,控制台报'Invalid JSON'
根本原因:代理返回的 JSON 格式与 Clawdbot 预期不符
Qwen3 的 Ollama API 返回的是/api/chat格式(含"message"字段),而 Clawdbot 期望/v1/chat/completions格式(含"choices"数组)。
解决方案:确保代理做了字段转换。在proxy.config.json同级目录,检查是否存在transform.js或adapter.js文件。一个最小可用的转换脚本如下(保存为/app/proxy/adapter.js):
module.exports = function(req, res, next) {
if (req.url === '/v1/chat/completions' && req.method === 'POST') {
let data = '';
req.pipe(require('http').request({
method: 'POST',
hostname: 'localhost',
port: 11434,
path: '/api/chat',
headers: { 'Content-Type': 'application/json' }
}, (proxyRes) => {
proxyRes.on('data', chunk => data += chunk);
proxyRes.on('end', () => {
try {
const ollamaResp = JSON.parse(data);
// 转换为 OpenAI 格式
const openaiResp = {
id: 'chat-' + Date.now(),
object: 'chat.completion',
created: Math.floor(Date.now() / 1000),
model: 'qwen3-32b',
choices: [{
index: 0,
message: { role: 'assistant', content: ollamaResp.message?.content || '' },
finish_reason: 'stop'
}],
usage: { prompt_tokens: 0, completion_tokens: 0, total_tokens: 0 }
};
res.json(openaiResp);
} catch (e) {
res.status(500).json({ error: 'Parse error' });
}
});
})).on('error', next);
return;
}
next();
};
此脚本确保无论 Ollama 返回什么,都包装成 Clawdbot 能识别的标准格式。
5.3 问题:响应速度慢,或长文本截断
- Qwen3-32B 对硬件要求高:该模型需至少 24GB 显存(推荐 32GB+)或 64GB 以上内存(CPU 推理)。若显存不足,Ollama 会自动降级为 CPU 模式,速度骤降。
检查 Ollama 日志:
ollama serve输出中是否有using cpu字样。如有,需升级 GPU 或改用更小模型(如qwen3:14b)。
Clawdbot 默认超时时间过短:在clawdbot.config.json中增加超时配置:
"requestTimeout": 120000
单位毫秒,此处设为 120 秒,足够 Qwen3-32B 完成复杂推理。
6. 进阶优化:让体验更稳定、更高效
通路跑通只是开始。以下是提升生产可用性的关键优化项:
6.1 启用 Qwen3 的混合思维模式(Thinking Mode)
Qwen3-32B 支持两种推理模式:
enable_thinking=true:深度推理,适合数学、代码、逻辑题,响应稍慢但质量高enable_thinking=false:极速响应,适合闲聊、摘要、简单问答,延迟低于 1 秒
在 Clawdbot 中,你可通过两种方式控制:
- 全局开关:在
clawdbot.config.json中设"enableThinkingMode": true - 单次指令:在聊天框输入
/think启用深度模式,输入/no_think切回极速模式
实测效果:开启
/think后,Qwen3-32B 解答微积分题的准确率提升约 40%,且步骤清晰;关闭后,日常对话平均响应时间从 3.2 秒降至 0.8 秒。
6.2 配置持久化会话与上下文管理
Clawdbot 默认不保存历史记录。如需多轮对话保持上下文,需启用其内置会话管理:
在clawdbot.config.json中添加:
"enableSessionHistory": true,
"maxContextLength": 8192
maxContextLength:设为 8192(Qwen3-32B 支持 128K 上下文,但前端为防 OOM 建议保守设为 8K)- 会话数据默认存在浏览器 Local Storage,关闭页面不丢失
6.3 日志监控与性能追踪
在代理服务中加入简易日志,便于排查:
// 在代理请求处理函数开头添加
console.log(`[PROXY] ${new Date().toISOString()} | ${req.method} ${req.url} → ${config.target}`);
查看日志:docker logs -f clawdbot-qwen3 | grep PROXY
7. 总结:你已掌握一条完全自主的大模型应用链路
回顾整个过程,你实际上完成了三件关键事:
- 搭建了私有推理底座:用 Ollama 一键部署 Qwen3-32B,无需编译、不碰 CUDA,模型即开即用;
- 构建了协议转换桥梁:通过轻量代理,把 Ollama 的
/api/chat无缝转为标准 OpenAI API,让任何兼容前端都能接入; - 配置了生产级交互界面:Clawdbot 不仅是个聊天框,更是可定制、可扩展、可审计的 AI 应用入口。
这条链路的价值,不在于技术多炫酷,而在于完全掌控权:
- 数据不出本地,合规无忧;
- 模型可随时切换(
qwen3:14b/qwen3:8b),成本按需调节; - 代理层可扩展功能(加鉴权、加审计日志、接企业微信),不依赖厂商 SDK。
下一步,你可以:
- 把 Clawdbot 嵌入公司内网,作为员工智能助手;
- 在代理层接入 RAG 插件,让 Qwen3 能查询你的知识库;
- 用
/think指令驱动 Qwen3 自动生成周报、分析销售数据、编写 SQL——真正让大模型成为你的数字同事。
技术从来不是目的,解决问题才是。而你,已经拿到了那把钥匙。

