# AI Video Assistant 平台 —— 开发常用命令 # # 用法:make <目标>,例如 make up / make db-seed。 # 多数目标是对 docker compose 的薄封装,集中沉淀平时手敲的开发脚本。 # 容器内执行 psql 的固定前缀(postgres/postgres/postgres,见 docker-compose.yaml) PSQL = docker compose exec -T postgres psql -U postgres -d postgres .DEFAULT_GOAL := help .PHONY: help up down restart logs api-logs db db-list db-seed db-seed-model-resources db-seed-assistants db-clear db-reset help: ## 列出所有可用目标 @grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) \ | awk 'BEGIN {FS = ":.*?## "}; {printf " \033[36m%-12s\033[0m %s\n", $$1, $$2}' # ---- 服务编排 ---- up: ## 起 postgres + api + ui docker compose up -d down: ## 停掉所有服务(保留数据卷) docker compose down restart: ## 重建 api 容器(改了 env/CORS 后用) docker compose up -d --force-recreate api logs: ## 跟随全部服务日志 docker compose logs -f api-logs: ## 只看后端日志 docker compose logs -f api # ---- 数据库 ---- db: ## 进入交互式 psql docker compose exec postgres psql -U postgres -d postgres db-list: ## 列出模型资源与助手 @$(PSQL) -c "SELECT id, name, capability, interface_type, is_default FROM model_resources ORDER BY id;" @$(PSQL) -c "SELECT id, name, type FROM assistants ORDER BY id;" db-seed-model-resources: ## 灌入 12 条模型资源种子(幂等) $(PSQL) < backend/db/seed_model_resources.sql db-seed-assistants: ## 灌入 知识库 + 助手 种子(幂等;依赖模型资源已就绪) $(PSQL) < backend/db/seed_assistants.sql db-seed: db-seed-model-resources db-seed-assistants ## 全量灌种子(模型资源→知识库→助手,幂等,可重复执行) db-clear: ## 清空 助手/知识库/模型资源(按依赖顺序) $(PSQL) -c "TRUNCATE assistant_model_bindings, assistants, knowledge_bases, model_resources CASCADE;" db-reset: db-clear db-seed ## 清空后重新灌全部种子