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.htmlconfig.json两个核心文件。

3.2 修改config.json适配本地环境

打开config.json,重点修改以下三处(其他字段保持默认):

{ "apiUrl": "http://localhost:8080/v1", "model": "qwen3:32B", "baseUrl": "http://localhost:18789" } 

关键点说明:

  • apiUrl必须指向我们刚起的8080代理,不能写11434
  • model字段必须和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.pyopenai_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.logtail -f proxy.log看是否有500 Internal Server Error或超时记录
http-server终端输出直接看启动终端看是否有404 Not Found或CORS警告
浏览器ConsoleF12 → 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. 总结:从连不上到丝滑对话的六个关键点

回顾整个调试过程,真正卡住大家的从来不是技术多难,而是几个细节没对齐:

  1. 端口不是数字游戏:18789是Clawdbot约定,8080是代理中转站,11434是Ollama原生端口——三者缺一不可,且不能互换
  2. 模型名必须一字不差qwen3:32Bqwen3:32bqwen3-32B,大小写和符号都要严格匹配
  3. 代理是协议翻译器:不是简单端口转发,必须把OpenAI的JSON结构转成Ollama能懂的格式
  4. 日志要三端联动看:前端Console、代理log、Ollama终端,漏掉任何一环都可能误判
  5. 超时设置要合理:Qwen3-32B首token延迟可能达8秒,代理timeout至少设为30秒
  6. 验证要分层进行:先测Ollama原生API → 再测代理层 → 最后测Clawdbot界面,层层递进

现在,当你在浏览器里输入http://localhost:18789,敲下“你好”,看到Qwen3-32B用中文流畅回复时,你就已经完成了私有大模型聊天平台最关键的一步——不是调通了某个API,而是打通了从用户输入到大模型思考的完整信任链。

下一步,你可以尝试把config.json里的model换成qwen3:7B做对比,感受不同参数规模下的响应速度差异;或者把代理脚本改成支持多模型路由,让一个端口服务多个大模型。

技术落地的魅力,永远在于“原来如此”的顿悟时刻,而不是堆砌术语的幻觉。


获取更多AI镜像

想探索更多AI镜像和应用场景?访问 ZEEKLOG星图镜像广场,提供丰富的预置镜像,覆盖大模型推理、图像生成、视频生成、模型微调等多个领域,支持一键部署。

Read more

多模态 AI 应用:图文音视频一体化开发实战教程

多模态 AI 应用:图文音视频一体化开发实战教程

什么是多模态AI 多模态AI是指能够同时处理文本、图像、音频、视频等多种不同类型数据的人工智能系统,它打破了单模态AI的信息壁垒,能更贴近人类理解世界的方式。比如我们日常使用的AI聊天机器人识图功能、视频自动字幕生成工具,都是多模态AI的典型应用。 开发前的核心准备 模型选型建议 模型类型推荐模型适用场景开源轻量模型Qwen-VL-Chat、MiniGPT-4本地部署、快速验证云端API模型GPT-4V、Gemini Pro生产级应用、复杂任务处理专业领域模型CLIP、Whisper图像检索、音频转写等细分场景 环境依赖安装 我们将基于Python生态实现实战项目,需要安装以下核心库: # 基础依赖 pip install torch torchvision transformers pillow # 音频处理依赖 pip install librosa soundfile # 视频处理依赖 pip install opencv-python moviepy # API调用依赖(可选,用于调用云端多模态模型) pip install openai anthropic

当AI学会写“自传”:OpenClaw 的 SOUL.md 如何把配置文件变成一颗会变形的心

在多数软件的世界里,配置文件像一张表格:端口、路径、开关,冷静到几乎没有呼吸。但在 OpenClaw 的工作区里,有一份文件看起来像散文——它叫 SOUL.md。我在阅读你提供的材料时最强烈的感受是:它并不是“把模型调得更像某种语气”的小旋钮,而是一套更大胆的提案——用一份纯 Markdown 的自然语言文本,把代理(Agent)的身份、价值观、沟通风格与行为边界写成可阅读、可编辑、甚至可自我改写的“灵魂”。 官方模板那句“You’re not a chatbot. You’re becoming someone.”几乎像小说的开场白:这不再是“加载配置”,而更像“宣告存在”。 🧠 灵魂不是参数:SOUL.md 的定位是一份“存在论文档” 如果我把传统

免费获得大模型的Api-Key的方法:英伟达提供GLM-4.7、Minimax M2.1模型和GitHub的AI大模型API申请

免费获得大模型的Api-Key的方法:英伟达提供GLM-4.7、Minimax M2.1模型和GitHub的AI大模型API申请 最近一直在玩OpenClaw,无奈OpenClaw是个消耗token的高手!随随便便问了几个问题就能吃掉百万的token数,妥妥的吞金兽,如果有免费的token就好了! 今天就给大家介绍英伟达和Github的免费大模型API Key的获取方法。 传送门: * • OpenRouter提供的DeepSeek-R1-70B的大模型免费用 * • 获取各大人工智能AI工具通过API和KEY调用的方法 英伟达-Nvidia的免费API Key 说到英伟达,大家的第一反应可能是"卖显卡的大佬"。但很少有人意识到,拥有强大算力的英伟达,也在积极布局AI云服务市场。这波免费开放API的策略,本质上是一个聪明的生态布局——通过免费服务吸引开发者,为未来的商业变现铺路。   注册账号 1.打开英伟达官网 https://build.nvidia.com 点击“Login”   2.输入邮箱 输入邮箱、密码   3.验

以为AI开发就是调接口?一场25K的面试让我看到真相,原来真正的技术深度在这!

以为AI开发就是调接口?一场25K的面试让我看到真相,原来真正的技术深度在这!

以为AI开发就是调接口?一场25K的面试让我看到真相,原来真正的技术深度在这! 核心观点:AI应用开发绝非简单的API调用,而是融合算法理解、系统架构、工程实践、业务洞察的综合性技术领域。 随着人工智能技术的爆发式增长,越来越多的企业和开发者涌入AI应用开发赛道。然而,一个普遍存在的认知偏见依然困扰着这个领域——**很多人认为AI应用开发本质上就是调用大模型API,难度系数不高。**这种表象化的理解,恰恰忽视了AI应用开发的深层技术复杂度。 通过一次极具代表性的技术面试,我们可以清晰地看到AI应用开发的真实技术图谱。同时,我们也将深入探讨这个领域的技术演进、最佳实践以及未来发展趋势。 文章目录 * 以为AI开发就是调接口?一场25K的面试让我看到真相,原来真正的技术深度在这! * 技术背景重构 * 面试者画像可视化 * AI应用开发的技术现状与挑战 * 技术生态的演进路径 * 提示词工程的深层逻辑 * 提示词工程的系统性方法论 * 1. 场景分类体系 * 2. 提示词模板管理 *