mkdir metapi && cd metapi
# 创建 docker-compose.yml(参见快速上手)
# 设置环境变量
export AUTH_TOKEN=your-admin-token
export PROXY_TOKEN=your-proxy-sk-token
# 启动
docker compose up -d如果不想每次 export,可以创建 .env 文件:
# .env
AUTH_TOKEN=your-admin-token
PROXY_TOKEN=your-proxy-sk-token
TZ=Asia/Shanghai
PORT=4000docker compose --env-file .env up -d
⚠️ .env文件包含敏感信息,请勿提交到 Git 仓库。
docker run -d --name metapi \
-p 4000:4000 \
-e AUTH_TOKEN=your-admin-token \
-e PROXY_TOKEN=your-proxy-sk-token \
-e TZ=Asia/Shanghai \
-v ./data:/app/data \
--restart unless-stopped \
1467078763/metapi:latest路径说明:
./data:/app/data— 相对路径,数据存到当前目录下的data文件夹- 也可以使用绝对路径:
/your/custom/path:/app/data
流式请求(SSE)需要关闭缓冲,否则流式输出会异常:
server {
listen 443 ssl;
server_name your-domain.com;
ssl_certificate /path/to/cert.pem;
ssl_certificate_key /path/to/key.pem;
location / {
proxy_pass http://127.0.0.1:4000;
# SSE 关键配置
proxy_buffering off;
proxy_cache off;
proxy_set_header Connection '';
proxy_http_version 1.1;
chunked_transfer_encoding off;
# 标准代理头
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 超时设置(长对话场景)
proxy_read_timeout 300s;
proxy_send_timeout 300s;
}
}your-domain.com {
reverse_proxy localhost:4000 {
flush_interval -1
}
}
# 拉取最新镜像
docker compose pull
# 重新启动(数据不受影响)
docker compose up -d
# 清理旧镜像
docker image prune -f如果升级后出现问题:
- 升级前备份(建议每次升级前执行):
cp -r data/ data-backup-$(date +%Y%m%d)/- 回滚到指定版本:
# 修改 docker-compose.yml 中的 image tag
# 例如:image: 1467078763/metapi:v1.0.0
# 恢复数据
rm -rf data/
cp -r data-backup-20260228/ data/
# 重启
docker compose up -dMetapi 的所有运行数据存储在 SQLite 数据库中,位于 DATA_DIR(默认 ./data)目录下。
只要挂载了该目录,升级、重启都不会丢失数据。
- 每日自动备份
data/目录 - 保留最近 7~30 天的备份
- 重要操作前手动快照