如果你需要频繁修改 app 或 frontend 代码,不需要每次都重新构建 Docker 镜像,可以使用本地开发模式。
make dev-start这将启动以下服务的 Docker 容器:
- PostgreSQL(数据库)
- Redis(缓存)
- MinIO(对象存储)
- Neo4j(图数据库)
- DocReader(文档读取服务)
- Jaeger(链路追踪)
make dev-app这将在本地直接运行 Go 应用,修改代码后 Ctrl+C 停止,重新运行即可。
make dev-frontend这将启动 Vite 开发服务器,支持热重载,修改代码后自动刷新。
make dev-statusmake dev-stop如果你更喜欢直接使用脚本:
# 启动基础设施
./scripts/dev.sh start
# 启动后端(新终端)
./scripts/dev.sh app
# 启动前端(新终端)
./scripts/dev.sh frontend
# 查看日志
./scripts/dev.sh logs
# 停止所有服务
./scripts/dev.sh stop- 前端开发服务器: http://localhost:5173
- 后端 API: http://localhost:8080
- PostgreSQL: localhost:5432
- Redis: localhost:6379
- MinIO Console: http://localhost:9001
- Neo4j Browser: http://localhost:7474
- Jaeger UI: http://localhost:16686
# 每次修改代码后都需要:
sh scripts/build_images.sh -p # 重新构建镜像(很慢)
sh scripts/start_all.sh --no-pull # 重启容器耗时:每次修改需要 2-5 分钟
# 首次启动(只需要一次):
make dev-start
# 在另外两个终端分别运行:
make dev-app # 修改 Go 代码后 Ctrl+C 重启即可(秒级)
make dev-frontend # 修改前端代码自动热重载(无需重启)耗时:
- 首次启动:1-2 分钟
- 后续修改后端:5-10 秒(重启 Go 应用)
- 后续修改前端:实时热重载
如果你希望后端代码修改后也能自动重启,可以安装 air:
go install github.com/air-verse/air@latest在项目根目录创建 .air.toml:
root = "."
testdata_dir = "testdata"
tmp_dir = "tmp"
[build]
args_bin = []
bin = "./tmp/main"
cmd = "go build -o ./tmp/main ./cmd/server"
delay = 1000
exclude_dir = ["assets", "tmp", "vendor", "testdata", "frontend", "migrations"]
exclude_file = []
exclude_regex = ["_test.go"]
exclude_unchanged = false
follow_symlink = false
full_bin = ""
include_dir = []
include_ext = ["go", "tpl", "tmpl", "html", "yaml"]
include_file = []
kill_delay = "0s"
log = "build-errors.log"
poll = false
poll_interval = 0
rerun = false
rerun_delay = 500
send_interrupt = false
stop_on_error = false
[color]
app = ""
build = "yellow"
main = "magenta"
runner = "green"
watcher = "cyan"
[log]
main_only = false
time = false
[misc]
clean_on_exit = false
[screen]
clear_on_rebuild = false
keep_scroll = true# 在项目根目录
air现在修改 Go 代码后会自动重新编译和重启!
如果只修改前端,只需要:
cd frontend
npm run dev前端会连接到 http://localhost:8080 的后端 API。
如果只修改后端,只需要:
# 启动基础设施
make dev-start
# 运行后端
make dev-app使用 VS Code 或 GoLand 的调试功能,配置连接到本地运行的 Go 应用。
VS Code 配置示例(.vscode/launch.json):
{
"version": "0.2.0",
"configurations": [
{
"name": "Launch Server",
"type": "go",
"request": "launch",
"mode": "auto",
"program": "${workspaceFolder}/cmd/server",
"env": {
"DB_HOST": "localhost",
"DOCREADER_ADDR": "localhost:50051",
"MINIO_ENDPOINT": "localhost:9000",
"REDIS_ADDR": "localhost:6379",
"OTEL_EXPORTER_OTLP_ENDPOINT": "localhost:4317",
"NEO4J_URI": "bolt://localhost:7687"
},
"args": []
}
]
}使用浏览器开发者工具即可,Vite 提供了 source map。
当你完成开发需要部署时,才需要构建镜像:
# 构建所有镜像
sh scripts/build_images.sh
# 或只构建特定镜像
sh scripts/build_images.sh -p # 只构建后端
sh scripts/build_images.sh -f # 只构建前端
sh scripts/build_images.sh -d # 只构建文档读取器
sh scripts/build_images.sh -s # 只构建沙箱镜像(Agent Skills 执行环境)
# 启动生产环境
sh scripts/start_all.shA: 确保先运行了 make dev-start,并等待所有服务启动完成(大约 30 秒)。
A: 检查前端的代理配置,确保 vite.config.ts 中配置了正确的代理。
A: DocReader 仍然使用 Docker 镜像,如果需要修改,需要重新构建:
sh scripts/build_images.sh -d
make dev-restart- 日常开发:使用
make dev-*命令,快速迭代 - 测试集成:使用
sh scripts/start_all.sh --no-pull测试完整环境 - 生产部署:使用
sh scripts/build_images.sh+sh scripts/start_all.sh