服务端部署
OpenViking 可以作为独立的 HTTP 服务器运行,允许多个客户端通过网络连接。
快速开始
# 使用初始化向导创建或刷新 ~/.openviking/ov.conf
openviking-server init
# 如果你在向导中选择 OpenAI Codex,init 会帮你处理 Codex 登录/导入
# 启动前校验本地配置、模型访问和鉴权状态
openviking-server doctor
# 配置文件在默认路径 ~/.openviking/ov.conf 时,直接启动
openviking-server
# 配置文件在其他位置时,通过 --config 指定
openviking-server --config /path/to/ov.conf
# 验证服务器是否运行
curl http://localhost:1933/health
# {"status": "ok"}命令行选项
| 选项 | 描述 | 默认值 |
|---|---|---|
--config | 配置文件路径 | ~/.openviking/ov.conf |
--host | 绑定的主机地址 | 127.0.0.1 |
--port | 绑定的端口 | 1933 |
示例
# 使用默认配置
openviking-server
# 使用自定义端口
openviking-server --port 8000
# 指定配置文件、主机地址和端口
openviking-server --config /path/to/ov.conf --host 127.0.0.1 --port 8000配置
服务端从 ov.conf 读取所有配置。配置文件各段详情见 配置指南。
ov.conf 中的 server 段控制服务端行为:
{
"server": {
"host": "0.0.0.0",
"port": 1933,
"root_api_key": "your-secret-root-key",
"cors_origins": ["*"]
},
"storage": {
"workspace": "./data",
"agfs": { "backend": "local" },
"vectordb": { "backend": "local" }
}
}部署模式
独立模式(嵌入存储)
服务器管理本地 RAGFS 和 VectorDB。在 ov.conf 中配置本地存储路径:
{
"storage": {
"workspace": "./data",
"agfs": { "backend": "local" },
"vectordb": { "backend": "local" }
}
}openviking-server使用 Systemd 部署服务(推荐)
对于 Linux 系统,可以使用 Systemd 服务来管理 OpenViking,实现自动重启、开机自启等功能。首先,你应该已经成功安装并配置了 OpenViking 服务器,确保它可以正常运行,再进行服务化部署。
创建 Systemd 服务文件
创建 /etc/systemd/system/openviking.service 文件:
[Unit]
Description=OpenViking HTTP Server
After=network.target
[Service]
Type=simple
# 替换为运行 OpenViking 的用户
User=your-username
# 替换为用户组
Group=your-group
# 替换为工作目录
WorkingDirectory=/var/lib/openviking
# 以下两种启动方式二选一
ExecStart=/path/to/your/python/bin/openviking-server
Restart=always
RestartSec=5
# 配置文件路径
Environment="OPENVIKING_CONFIG_FILE=/etc/openviking/ov.conf"
[Install]
WantedBy=multi-user.target管理服务
创建好服务文件后,使用以下命令管理 OpenViking 服务:
# 重载 systemd 配置
sudo systemctl daemon-reload
# 启动服务
sudo systemctl start openviking.service
# 设置开机自启
sudo systemctl enable openviking.service
# 查看服务状态
sudo systemctl status openviking.service
# 查看服务日志
sudo journalctl -u openviking.service -f连接客户端
Python SDK
import openviking as ov
client = ov.SyncHTTPClient(url="http://localhost:1933", api_key="your-key")
client.initialize()
results = client.find("how to use openviking")
client.close()CLI
CLI 从 ovcli.conf 读取连接配置。在 ~/.openviking/ovcli.conf 中配置:
{
"url": "http://localhost:1933",
"api_key": "your-key"
}也可通过 OPENVIKING_CLI_CONFIG_FILE 环境变量指定配置文件路径:
export OPENVIKING_CLI_CONFIG_FILE=/path/to/ovcli.confcurl
curl http://localhost:1933/api/v1/fs/ls?uri=viking:// \
-H "X-API-Key: your-key"云原生部署
Docker
OpenViking 提供预构建的 Docker 镜像,发布在 GitHub Container Registry。容器内所有持久化状态(ov.conf、ovcli.conf 以及工作区数据)都放在 /app/.openviking 下,挂载一个目录即可:
docker run -d \
--name openviking \
-p 1933:1933 \
-v ~/.openviking:/app/.openviking \
--restart unless-stopped \
ghcr.io/volcengine/openviking:latestDocker 镜像默认会同时启动:
- OpenViking HTTP 服务,端口
1933(绑定0.0.0.0),同时在/studio提供 Web Studio 前端 vikingbotgateway
由于容器内服务绑定 0.0.0.0(Docker 端口映射所必需),你必须在 ov.conf 中设置 root_api_key:
{
"server": {
"root_api_key": "your-secret-root-key"
}
}未设置时服务将拒绝启动。如需自定义绑定地址,可通过环境变量 OPENVIKING_SERVER_HOST 覆盖。
升级容器的方式
docker stop openviking
docker pull ghcr.io/volcengine/openviking:latest
docker rm -f openviking
# 然后重新 docker run ...如果你希望本次容器启动时关闭 vikingbot,可以使用下面任一方式:
docker run -d \
--name openviking \
-p 1933:1933 \
-v ~/.openviking:/app/.openviking \
--restart unless-stopped \
ghcr.io/volcengine/openviking:latest \
--without-botdocker run -d \
--name openviking \
-e OPENVIKING_WITH_BOT=0 \
-p 1933:1933 \
-v ~/.openviking:/app/.openviking \
--restart unless-stopped \
ghcr.io/volcengine/openviking:latest无法使用 docker -v 时
部分托管平台(如 Railway、Fly.io、Heroku 这类 PaaS)不支持把宿主机目录绑定挂载进容器。这种环境下,如果容器启动时找不到 ov.conf,entrypoint 不会崩溃 —— 它会打印一段修复指引并阻塞等待文件出现。你可以选用以下两种方式之一:
方案 A:通过 OPENVIKING_CONF_CONTENT 注入完整配置内容。 entrypoint 会在启动 server 前把这个环境变量的值写入到 OPENVIKING_CONFIG_FILE(默认 /app/.openviking/ov.conf):
docker run -d \
--name openviking \
-p 1933:1933 \
-e OPENVIKING_CONF_CONTENT="$(cat ~/.openviking/ov.conf)" \
--restart unless-stopped \
ghcr.io/volcengine/openviking:latest方案 B:容器起来之后再 docker exec 进去用向导配置。 容器在等待 ov.conf 期间是存活的,exec 进去运行 setup wizard,它会按 OPENVIKING_CONFIG_FILE 写到 server 正在监听的位置:
docker exec -it openviking openviking-server initov.conf 出现后,entrypoint 会自动恢复并启动 server。
也可以使用 Docker Compose,项目根目录提供了 docker-compose.yml:
docker compose up -d启动后可以访问:
- API 服务:
http://localhost:1933 - Web Studio:
http://localhost:1933/studio(与 API 同源) - 兼容入口:
http://localhost:1934(Caddy 反代到 1933,仅为已有部署保留)
多实例部署注意事项
多实例部署时,通常建议注意这几项配置:
- 把
server.temp_upload.default_mode设为"shared",这样临时上传文件可以被其他副本消费。 - 只有在多个实例明确共享同一个
storage.workspace时,才考虑把storage.skip_process_lock设为true。启用后,OpenViking 不会再检查或创建.openviking.pid。 - 对 QueueFS,建议通过
storage.agfs.queuefs.db_path显式指定实例本地的 SQLite 路径。如果启用了 usage audit,建议通过server.observability.usage_audit.sqlite_path显式指定实例本地的 SQLite 路径,不要默认和共享 workspace 卷混用。
示例:
{
"server": {
"temp_upload": {
"default_mode": "shared"
}
},
"storage": {
"skip_process_lock": true
}
}这个示例只适用于多个实例明确共享同一个 workspace 的场景。如果每个实例都有自己的本地 workspace,不要开启 skip_process_lock。
如果你还需要为 QueueFS 和 usage audit 显式指定本地 SQLite 路径,可以参考:
{
"server": {
"temp_upload": {
"default_mode": "shared"
},
"observability": {
"usage_audit": {
"sqlite_path": "/var/lib/openviking-local/usage_audit.sqlite3"
}
}
},
"storage": {
"skip_process_lock": true,
"agfs": {
"queuefs": {
"db_path": "/var/lib/openviking-local/queue.db"
}
}
}
}这个变体适用于多个实例共享同一个 workspace,但 QueueFS 和 usage audit 的 SQLite 文件仍然放在各实例本地路径的场景。
如需公网 HTTPS 访问,请参考 公网访问指南。
如需自行构建镜像,请显式传入 OpenViking 版本: docker build --build-arg OPENVIKING_VERSION=0.3.12 -t openviking:latest .
Kubernetes + Helm
项目提供了 Helm chart,位于 examples/k8s-helm/:
helm install openviking ./examples/k8s-helm \
--set openviking.config.embedding.dense.api_key="YOUR_API_KEY" \
--set openviking.config.vlm.api_key="YOUR_API_KEY"详细的云上部署指南(包括火山引擎 TOS + VikingDB + 方舟配置)请参考 云上部署指南。
健康检查
| 端点 | 认证 | 用途 |
|---|---|---|
GET /health | 否 | 存活探针 — 立即返回 {"status": "ok"} |
GET /ready | 否 | 就绪探针 — 检查 AGFS、VectorDB、APIKeyManager、Embedding、Ollama |
# 存活探针
curl http://localhost:1933/health
# 就绪探针
curl http://localhost:1933/ready
# {"status": "ready", "checks": {"agfs": "ok", "vectordb": "ok", "api_key_manager": "ok", "embedding": "ok", "ollama": "ok"}}在 Kubernetes 中,使用 /health 作为存活探针,/ready 作为就绪探针。
相关文档
- 公网访问与反向代理 - HTTPS、Caddy、nginx
- 认证 - API Key 设置
- OAuth 接入指南 - 面向 MCP 客户端的 OAuth 2.1
- 可观测性与排障 - 健康检查、追踪与排障
- API 概览 - 完整 API 参考
