milvus/cmd/tools/migration/backend/etcd220.go
yah01 aa6b8af80d
Migrate metadata of QueryCoord from 2.1 to 2.2 (#19986)
Signed-off-by: yah01 <yang.cen@zilliz.com>

Signed-off-by: yah01 <yang.cen@zilliz.com>
2022-10-24 23:41:35 +08:00

142 lines
2.6 KiB
Go

package backend
import (
"fmt"
"github.com/milvus-io/milvus/cmd/tools/migration/configs"
"github.com/milvus-io/milvus/internal/util"
"github.com/milvus-io/milvus/cmd/tools/migration/meta"
"github.com/milvus-io/milvus/internal/metastore/kv/rootcoord"
)
// etcd220 implements Backend.
type etcd220 struct {
Backend
*etcdBasedBackend
}
func newEtcd220(cfg *configs.MilvusConfig) (*etcd220, error) {
etcdBackend, err := newEtcdBasedBackend(cfg)
if err != nil {
return nil, err
}
return &etcd220{etcdBasedBackend: etcdBackend}, nil
}
func lineSaveTo(key string) {
fmt.Printf("save to %s\n", key)
}
func printSaves(saves map[string]string) {
for k := range saves {
lineSaveTo(k)
}
}
func (b etcd220) save(saves map[string]string) error {
for k, v := range saves {
if err := b.txn.Save(k, v); err != nil {
return err
}
}
return nil
}
func (b etcd220) Save(metas *meta.Meta) error {
{
saves, err := metas.Meta220.TtCollections.GenerateSaves(metas.SourceVersion)
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.Collections.GenerateSaves(metas.SourceVersion)
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.TtAliases.GenerateSaves()
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.Aliases.GenerateSaves()
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.CollectionIndexes.GenerateSaves()
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.SegmentIndexes.GenerateSaves()
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.CollectionLoadInfos.GenerateSaves()
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
{
saves, err := metas.Meta220.PartitionLoadInfos.GenerateSaves()
if err != nil {
return err
}
if err := b.save(saves); err != nil {
return err
}
}
return nil
}
func (b etcd220) Clean() error {
prefixes := []string{
rootcoord.CollectionMetaPrefix,
rootcoord.PartitionMetaPrefix,
rootcoord.FieldMetaPrefix,
rootcoord.AliasMetaPrefix,
util.FieldIndexPrefix,
util.SegmentIndexPrefix,
}
for _, prefix := range prefixes {
if err := b.CleanWithPrefix(prefix); err != nil {
return err
}
lineCleanPrefix(prefix)
}
return nil
}