使用 Docker Compose 升级 Milvus 集群
本主题描述如何使用 Docker Compose 升级您的 Milvus。
在正常情况下,您可以通过更改镜像来升级 Milvus。但是,从 v2.1.x 升级到 v2.5.10 的任何升级之前,您需要迁移元数据。
通过更改镜像升级 Milvus
在正常情况下,您可以按照以下方式升级 Milvus:
-
在
docker-compose.yaml
中更改 Milvus 镜像标签。请注意,您需要为 Proxy、所有协调器和所有工作节点更改镜像标签。
...
rootcoord:
container_name: milvus-rootcoord
image: milvusdb/milvus:v2.5.10
...
proxy:
container_name: milvus-proxy
image: milvusdb/milvus:v2.5.10
...
querycoord:
container_name: milvus-querycoord
image: milvusdb/milvus:v2.5.10
...
querynode:
container_name: milvus-querynode
image: milvusdb/milvus:v2.5.10
...
indexcoord:
container_name: milvus-indexcoord
image: milvusdb/milvus:v2.5.10
...
indexnode:
container_name: milvus-indexnode
image: milvusdb/milvus:v2.5.10
...
datacoord:
container_name: milvus-datacoord
image: milvusdb/milvus:v2.5.10
...
datanode:
container_name: milvus-datanode
image: milvusdb/milvus:v2.5.10 -
运行以下命令执行升级。
docker compose down
docker compose up -d
迁移元数据
-
停止所有 Milvus 组件。
docker stop <milvus-component-docker-container-name>
-
准备元数据迁移的配置文件
migrate.yaml
。# migration.yaml
cmd:
# Option: run/backup/rollback
type: run
runWithBackup: true
config:
sourceVersion: 2.1.4 # Specify your milvus version
targetVersion: 2.5.10
backupFilePath: /tmp/migration.bak
metastore:
type: etcd
etcd:
endpoints:
- milvus-etcd:2379 # Use the etcd container name
rootPath: by-dev # The root path where data is stored in etcd
metaSubPath: meta
kvSubPath: kv -
运行迁移容器。
# Suppose your docker-compose run with the default milvus network,
# and you put migration.yaml in the same directory with docker-compose.yaml.
docker run --rm -it --network milvus -v $(pwd)/migration.yaml:/milvus/configs/migration.yaml milvus/meta-migration:v2.2.0 /milvus/bin/meta-migration -config=/milvus/configs/migration.yaml -
使用新的 Milvus 镜像再次启动 Milvus 组件。
Update the milvus image tag in the docker-compose.yaml
docker compose down
docker compose up -d
下一步
- 您可能还想了解如何:
- 如果您准备在云上部署集群: