如何调试coze-studio

coze-studio的源码下了好几天了,看看怎么调试

docker compose启动

官方文档

https://github.com/coze-dev/coze-studio/wiki/2.-Quickstart

复制配置文件

bash 复制代码
cd coze-studio
# Copy model configuration template
cp backend/conf/model/template/model_template_ark_doubao-seed-1.6.yaml backend/conf/model/ark_doubao-seed-1.6.yaml

创建环境变量文件并启动

复制代码
cd docker
cp .env.example .env
docker compose --profile '*' up -d

只是下载镜像要久一点,镜像好了直接启动就可以了,下面是需要的镜像列表,其中coze-server默认用的latest标签,为了版本清晰一些,我修改了docker-compose.yml的版本号

复制代码
"mysql:8.4.5",  
"bitnami/redis:8.0",  
"bitnami/elasticsearch:8.18.0",  
"minio/minio:RELEASE.2025-06-13T11-33-47Z-cpuv1",  
"bitnami/etcd:3.5",  
"milvusdb/milvus:v2.5.10",  
"nsqio/nsq:v1.2.1",  
"alpine/curl:8.12.1",  
"minio/mc:RELEASE.2025-05-21T01-59-54Z-cpuv1",  
"arigaio/atlas:0.35.0-community-alpine"
"opencoze/opencoze:0.3.1"

镜像下载方法可以看我另一篇文章《GithubAction同步镜像到阿里云仓库》

https://mp.weixin.qq.com/s/g8mugs21Y7yfGeoRMwVvkA

启动成功如下

登录web

访问ip:8888端口

编译源码

官方文档如下

https://github.com/coze-dev/coze-studio/wiki/7.-Development-Standards#code-development-and-testing

执行命令make server即可

coze-server的编译命令得看Makefile中的server规则

调用的scripts/setup/server.sh脚本编译和启动coze-server, 代码入口是backend/main.go

编译前需要

  1. docker compose成功启动了coze
  2. 安装gonodejs

在编译的过程中,可能还需要设置git邮箱

编译server的前会先编译前端代码,在安装依赖或运行打包脚本时,可能会执行 Git 相关命令(如验证作者身份),如果你的 Git 没有设置 user.email,就会失败。

bash 复制代码
git config --global user.name "xxxxx"
git config --global user.email "you@example.com"

调试coze-server

docker-compose.yml中可以看到,各个服务都做了端口映射,所以只需要通过docker compose启动好应用后,停止掉coze-server ,然后本地启动coze-server进行调试即可。

修改编译命令

修改scripts/setup/server.sh如下

删除当前正在运行的coze server镜像

docker目录下执行下面的命令,停止coze-server

bash 复制代码
docker compose --profile "*" rm -s -f coze-server

编译coze-server源码

项目根目录下,执行make server,就会编译前端、编译server。编译完成后,二进制文件会输出到项目根目录下的bin目录中,然后会调用 xxxx/coze-studio/bin/open -start命令启动server

调试server代码

退出前面启动的server,在项目根目录下创建调试脚本debug.sh

bash 复制代码
#!/bin/bash

BASE_DIR=$(pwd)
BACKEND_DIR="$BASE_DIR/backend"
BIN_DIR="$BASE_DIR/bin"
CONFIG_DIR="$BIN_DIR/resources/conf"
RESOURCES_DIR="$BIN_DIR/resources/"
DOCKER_DIR="$BASE_DIR/docker"
source "$DOCKER_DIR/.env"

echo "📑 Copying environment file..."
if [ -f "$DOCKER_DIR/.env" ]; then
    cp "$DOCKER_DIR/.env" "$BIN_DIR/.env"
else
    echo "error: .env file not found in $DOCKER_DIR"
    exit 1
fi

if [ -f "$DOCKER_DIR/cert.pem" ]; then
    cp "$DOCKER_DIR/cert.pem" "$BIN_DIR/cert.pem"
fi

if [ -f "$DOCKER_DIR/key.pem" ]; then
    cp "$DOCKER_DIR/key.pem" "$BIN_DIR/key.pem"
fi

echo "Cleaning configuration files..."
rm -rf "$CONFIG_DIR"
mkdir -p "$CONFIG_DIR"

cp -r "$BACKEND_DIR/conf" "$RESOURCES_DIR"
cp -r "$BACKEND_DIR/static" "$RESOURCES_DIR"

cd $BIN_DIR && dlv --headless --listen=:7000 --api-version=2 --accept-multiclient --log exec -- /root/coze-studio/bin/opencoze -start

因为server启动的时候,需要复制一下配置文件,参考源码的server.sh脚本的逻辑,编写了debug.sh脚本。不使用debug.sh脚本就要手动复制配置文件了。

脚本编写好后,赋予脚本执行权限chmod +x debug.sh

执行脚本,输出如下内容

vscode debug

配置项如下

可以开始调试了

如果调试太卡可以把dlv的日志选项去掉会快一些

相关推荐
Huang2601083 分钟前
Producer Audios Generation API 集成指南
ai
java_logo11 分钟前
SiYuan 思源笔记 Docker 部署终极指南:Windows+Linux 双平台
windows·笔记·docker·思源笔记·思源笔记部署·docker部署思源笔记·思源笔记文档
ykjhr_3d19 分钟前
数字工具AI智能学伴,助力教育数字化转型
大数据·人工智能·ai·ai人工智能·华锐视点·华锐云空间
LIUAWEIO22 分钟前
鸽鸽工具网:免费在线工具大全,打开网页即用
人工智能·安全·ai·json
饭后一颗花生米24 分钟前
养马养虾助手免费下载免费安装教程,一键部署永久使用
ai
d111111111d25 分钟前
了解Modbus
网络·笔记·stm32·单片机·嵌入式硬件·学习
愚昧之山绝望之谷开悟之坡37 分钟前
什么agentskill.io大白话说清楚
笔记
维元码簿44 分钟前
Claude Code 深度拆解:Agent 执行内核 2 — Pipeline 与上下文压缩
ai·agent·claude code·ai coding
hrhcode1 小时前
【LangGraph】二.State 和 Node 的设计细节
python·ai·langchain·langgraph·ai框架
其实防守也摸鱼1 小时前
带你了解与配置phpmyadmin
笔记·安全·网络安全·pdf·编辑器·工具·调试