Clawdbot整合Qwen3-32B保姆级教程:Web网关18789端口调试全记录
Clawdbot整合Qwen3-32B保姆级教程:Web网关18789端口调试全记录
1. 为什么需要这个整合方案
你是不是也遇到过这样的问题:想用本地部署的大模型做聊天机器人,但发现直接调用Ollama的API在Web前端里跨域报错?或者Clawdbot配置完后一直连不上模型,控制台疯狂刷404?又或者好不容易跑起来了,发个消息却卡在“正在思考”半天没反应?
这正是我们搭建这套环境时踩过的坑。Clawdbot本身不直接对接Ollama,它需要一个中间层来处理协议转换、请求转发和端口映射。而18789这个端口,就是整个链路里最关键的“通关密码”——它不是随便选的,而是Clawdbot默认监听的Web网关入口。
整套方案的核心逻辑其实很朴素:
- 你在浏览器里访问
http://localhost:18789,看到的是Clawdbot的聊天界面 - Clawdbot收到你的消息后,不自己去算答案,而是把请求转给内部代理
- 代理再把请求发到
http://localhost:8080(Ollama API地址) - Ollama调用本地的Qwen3-32B模型生成回复,原路返回
整个过程对用户完全透明,你只管打字,剩下的交给这三层接力。
我们不用Docker Compose写一堆yaml,也不搞Kubernetes集群,就用最轻量、最可控的方式——纯命令行+配置文件,每一步都能看见、能改、能查。
2. 环境准备与基础服务启动
2.1 确认系统前提条件
请先在终端里运行这几条命令,确认基础环境已就绪:
# 检查Node.js版本(Clawdbot需要18.x或更高) node --version # 检查Ollama是否已安装并运行 ollama list curl -s http://localhost:11434/api/tags | jq '.models[] | select(.name | contains("qwen3"))' # 检查Python是否可用(部分代理脚本依赖) python3 --version 如果ollama list没显示qwen3:32B,先拉取模型:
ollama pull qwen3:32B 注意:Qwen3-32B是大模型,首次拉取可能需要30分钟以上,请确保磁盘空间充足(建议预留25GB以上)。不要用qwen3:latest,必须明确指定:32B标签,否则可能加载错版本导致后续报错。
2.2 启动Ollama服务并验证API
Ollama默认监听127.0.0.1:11434,但Clawdbot需要的是标准HTTP API格式。我们先手动测试一下原始接口是否通:
curl -X POST http://localhost:11434/api/chat \ -H "Content-Type: application/json" \ -d '{ "model": "qwen3:32B", "messages": [{"role": "user", "content": "你好"}], "stream": false }' | jq '.message.content' 如果返回“你好!很高兴见到你”,说明Ollama工作正常。如果报错Connection refused,请检查Ollama服务是否真的在后台运行(ps aux | grep ollama)。
2.3 创建轻量代理层(关键步骤)
Clawdbot不能直连Ollama的11434端口,因为它的前端代码硬编码了/v1/chat/completions路径,而Ollama用的是/api/chat。我们需要一个“翻译官”。
我们不用Nginx或Caddy这种重型网关,写一个50行以内的Python代理脚本,保存为proxy_8080.py:
#!/usr/bin/env python3 import asyncio import json from aiohttp import web, ClientSession OLLAMA_URL = "http://localhost:11434/api/chat" TIMEOUT = 300 async def handle_chat(request): try: data = await request.json() # 将OpenAI格式转为Ollama格式 ollama_data = { "model": data.get("model", "qwen3:32B"), "messages": [{"role": m["role"], "content": m["content"]} for m in data.get("messages", [])], "stream": data.get("stream", False), } async with ClientSession() as session: async with session.post( OLLAMA_URL, json=ollama_data, timeout=asyncio.Timeout(TIMEOUT) ) as resp: if resp.status == 200: response_data = await resp.json() # 转回OpenAI兼容格式 openai_resp = { "id": "chat-" + str(hash(json.dumps(data)))[:8], "object": "chat.completion", "created": int(__import__('time').time()), "model": ollama_data["model"], "choices": [{ "index": 0, "message": {"role": "assistant", "content": response_data.get("message", {}).get("content", "")}, "finish_reason": "stop" }] } return web.json_response(openai_resp) else: return web.Response(text=await resp.text(), status=resp.status) except Exception as e: return web.json_response({"error": str(e)}, status=500) app = web.Application() app.router.add_post("/v1/chat/completions", handle_chat) web.run_app(app, host="127.0.0.1", port=8080, print=False) 赋予执行权限并后台运行:
chmod +x proxy_8080.py nohup python3 proxy_8080.py > proxy.log 2>&1 & 验证代理是否生效:
curl -X POST http://localhost:8080/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "qwen3:32B", "messages": [{"role": "user", "content": "用一句话介绍你自己"}] }' | jq '.choices[0].message.content' 看到Qwen3的回答,说明8080端口代理已就位。
3. Clawdbot部署与18789端口配置
3.1 下载并解压Clawdbot
Clawdbot是静态前端项目,无需编译。从官方GitHub Release下载最新版(截至2026年1月为v0.8.2):
wget https://github.com/clawdbot/clawdbot/releases/download/v0.8.2/clawdbot-v0.8.2.zip unzip clawdbot-v0.8.2.zip -d clawdbot cd clawdbot 进入目录后,你会看到index.html和config.json两个核心文件。
3.2 修改config.json适配本地环境
打开config.json,重点修改以下三处(其他字段保持默认):
{ "apiUrl": "http://localhost:8080/v1", "model": "qwen3:32B", "baseUrl": "http://localhost:18789" } 关键点说明:
apiUrl必须指向我们刚起的8080代理,不能写11434model字段必须和Ollama里ollama list显示的名称完全一致(包括大小写和冒号)baseUrl是Clawdbot自身服务的地址,也就是我们要监听的18789端口
3.3 启动Clawdbot Web服务
Clawdbot自带简易HTTP服务器,一行命令启动:
npx http-server -p 18789 -c-1 -c-1表示禁用缓存,避免配置修改后页面不刷新;-p 18789明确指定端口。不要用python3 -m http.server 18789,它不支持前端路由,会导致页面白屏。
启动成功后,终端会显示:
Starting up http-server, serving ./ Available on: http://127.0.0.1:18789 http://192.168.1.100:18789 Hit CTRL-C to stop the server 此时打开浏览器访问 http://localhost:18789,就能看到Clawdbot的聊天界面。
4. 18789端口调试全流程实录
4.1 常见连接失败的三种典型场景
我们把调试过程拆成三步,每步都对应一个真实报错截图(文中已引用),你可以对照自查:
第一步:浏览器能打开页面,但输入消息后无响应
→ 打开浏览器开发者工具(F12),切到Network标签页,发送一条消息
→ 查看/v1/chat/completions请求的状态码
→ 如果是Failed to load resource: net::ERR_CONNECTION_REFUSED,说明8080代理没起来,回到2.3节重启代理
第二步:请求发出,但返回400 Bad Request
→ 点开该请求,看Response内容
→ 如果是{"error":"model not found"},说明config.json里的model名和Ollama不一致,重新核对ollama list输出
第三步:请求成功返回,但Clawdbot界面上显示“Error: Invalid response”
→ 这是格式不兼容的典型表现,说明代理脚本没把Ollama响应正确转成OpenAI格式
→ 检查proxy_8080.py中openai_resp构造部分,特别是response_data.get("message", {}).get("content", "")这一行是否取到了值
4.2 抓包验证完整链路(推荐用curl模拟)
为了彻底理清数据流向,我们跳过浏览器,用curl手动走一遍全流程:
# 1. 模拟Clawdbot向代理发请求(等效于前端AJAX) curl -X POST http://localhost:8080/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "qwen3:32B", "messages": [{"role": "user", "content": "今天天气怎么样?"}] }' # 2. 模拟代理向Ollama发请求(等效于proxy_8080.py内部调用) curl -X POST http://localhost:11434/api/chat \ -H "Content-Type: application/json" \ -d '{ "model": "qwen3:32B", "messages": [{"role": "user", "content": "今天天气怎么样?"}], "stream": false }' 如果第2步有返回,第1步没返回,问题一定出在代理脚本;如果两步都有返回,但Clawdbot仍报错,问题就在前端配置或网络策略。
4.3 日志定位法:三日志联动分析
当界面卡住时,同时查看三个日志文件:
| 日志位置 | 查看命令 | 关键线索 |
|---|---|---|
proxy.log | tail -f proxy.log | 看是否有500 Internal Server Error或超时记录 |
http-server终端输出 | 直接看启动终端 | 看是否有404 Not Found或CORS警告 |
| 浏览器Console | F12 → Console | 看是否有Uncaught (in promise)错误 |
举个真实案例:某次调试中,proxy.log显示ReadTimeoutError,但Ollama本身响应很快。最后发现是代理脚本里TIMEOUT = 300写成了3000(单位是秒),导致等待3000秒才超时,前端早已放弃。改成300后问题解决。
5. 进阶优化与稳定性加固
5.1 让服务开机自启(Linux/macOS)
把两个服务做成systemd服务,避免每次重启都要手动拉起:
创建/etc/systemd/system/ollama-proxy.service:
[Unit] Description=Ollama to OpenAI API Proxy After=ollama.service [Service] Type=simple User=$USER WorkingDirectory=/path/to/your/proxy ExecStart=/usr/bin/python3 /path/to/your/proxy_8080.py Restart=always RestartSec=10 [Install] WantedBy=multi-user.target 启用服务:
sudo systemctl daemon-reload sudo systemctl enable ollama-proxy sudo systemctl start ollama-proxy 同理为Clawdbot创建clawdbot-web.service,用npx http-server启动。
5.2 内存与显存监控(Qwen3-32B专属)
Qwen3-32B在推理时会占用约20GB显存(A10G)或35GB内存(CPU模式)。建议加装监控:
# 实时查看Ollama内存占用 ollama serve & # 确保服务在前台运行,便于观察日志 # 在另一个终端运行 watch -n 1 'nvidia-smi --query-gpu=memory.used --format=csv,noheader,nounits | head -1' 如果显存持续95%以上,考虑在config.json中添加流式响应开关(需Clawdbot v0.8.2+):
"stream": true 这样Ollama会边生成边返回token,降低内存峰值。
5.3 安全加固:限制本地访问
18789端口默认只监听127.0.0.1,但如果你用http-server -a 0.0.0.0开放了外网,务必加一层基础认证:
# 安装带认证的http-server npm install -g http-server-auth # 启动时加用户名密码 http-server-auth -p 18789 -u admin -p your_secure_password 这样即使端口暴露,没有凭证也无法访问聊天界面。
6. 总结:从连不上到丝滑对话的六个关键点
回顾整个调试过程,真正卡住大家的从来不是技术多难,而是几个细节没对齐:
- 端口不是数字游戏:18789是Clawdbot约定,8080是代理中转站,11434是Ollama原生端口——三者缺一不可,且不能互换
- 模型名必须一字不差:
qwen3:32B≠qwen3:32b≠qwen3-32B,大小写和符号都要严格匹配 - 代理是协议翻译器:不是简单端口转发,必须把OpenAI的JSON结构转成Ollama能懂的格式
- 日志要三端联动看:前端Console、代理log、Ollama终端,漏掉任何一环都可能误判
- 超时设置要合理:Qwen3-32B首token延迟可能达8秒,代理timeout至少设为30秒
- 验证要分层进行:先测Ollama原生API → 再测代理层 → 最后测Clawdbot界面,层层递进
现在,当你在浏览器里输入http://localhost:18789,敲下“你好”,看到Qwen3-32B用中文流畅回复时,你就已经完成了私有大模型聊天平台最关键的一步——不是调通了某个API,而是打通了从用户输入到大模型思考的完整信任链。
下一步,你可以尝试把config.json里的model换成qwen3:7B做对比,感受不同参数规模下的响应速度差异;或者把代理脚本改成支持多模型路由,让一个端口服务多个大模型。
技术落地的魅力,永远在于“原来如此”的顿悟时刻,而不是堆砌术语的幻觉。
获取更多AI镜像
想探索更多AI镜像和应用场景?访问 ZEEKLOG星图镜像广场,提供丰富的预置镜像,覆盖大模型推理、图像生成、视频生成、模型微调等多个领域,支持一键部署。