2022-08-25 07:48:54 +00:00
|
|
|
package indexnode
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/golang/protobuf/proto"
|
2022-10-19 08:55:27 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/common"
|
2022-09-09 07:52:35 +00:00
|
|
|
"go.uber.org/zap"
|
2022-08-25 07:48:54 +00:00
|
|
|
|
2022-10-16 12:49:27 +00:00
|
|
|
"github.com/milvus-io/milvus-proto/go-api/commonpb"
|
2022-09-24 05:40:52 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/log"
|
2022-08-25 07:48:54 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/proto/indexpb"
|
|
|
|
)
|
|
|
|
|
2022-09-06 09:19:11 +00:00
|
|
|
func (i *IndexNode) loadOrStoreTask(ClusterID string, buildID UniqueID, info *taskInfo) *taskInfo {
|
2022-08-25 07:48:54 +00:00
|
|
|
i.stateLock.Lock()
|
|
|
|
defer i.stateLock.Unlock()
|
2022-09-06 09:19:11 +00:00
|
|
|
key := taskKey{ClusterID: ClusterID, BuildID: buildID}
|
2022-08-25 07:48:54 +00:00
|
|
|
oldInfo, ok := i.tasks[key]
|
|
|
|
if ok {
|
|
|
|
return oldInfo
|
|
|
|
}
|
|
|
|
i.tasks[key] = info
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-09-23 01:40:52 +00:00
|
|
|
func (i *IndexNode) loadTaskState(ClusterID string, buildID UniqueID) commonpb.IndexState {
|
2022-09-06 09:19:11 +00:00
|
|
|
key := taskKey{ClusterID: ClusterID, BuildID: buildID}
|
2022-08-25 07:48:54 +00:00
|
|
|
i.stateLock.Lock()
|
|
|
|
defer i.stateLock.Unlock()
|
|
|
|
task, ok := i.tasks[key]
|
2022-09-23 01:40:52 +00:00
|
|
|
if !ok {
|
|
|
|
return commonpb.IndexState_IndexStateNone
|
|
|
|
}
|
|
|
|
return task.state
|
2022-08-25 07:48:54 +00:00
|
|
|
}
|
|
|
|
|
2022-09-06 09:19:11 +00:00
|
|
|
func (i *IndexNode) storeTaskState(ClusterID string, buildID UniqueID, state commonpb.IndexState, failReason string) {
|
|
|
|
key := taskKey{ClusterID: ClusterID, BuildID: buildID}
|
2022-08-25 07:48:54 +00:00
|
|
|
i.stateLock.Lock()
|
|
|
|
defer i.stateLock.Unlock()
|
|
|
|
if task, ok := i.tasks[key]; ok {
|
2022-09-09 07:52:35 +00:00
|
|
|
log.Debug("IndexNode store task state", zap.String("clusterID", ClusterID), zap.Int64("buildID", buildID),
|
|
|
|
zap.String("state", state.String()), zap.String("fail reason", failReason))
|
2022-08-25 07:48:54 +00:00
|
|
|
task.state = state
|
2022-09-06 09:19:11 +00:00
|
|
|
task.failReason = failReason
|
2022-08-25 07:48:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-06 09:19:11 +00:00
|
|
|
func (i *IndexNode) foreachTaskInfo(fn func(ClusterID string, buildID UniqueID, info *taskInfo)) {
|
2022-08-25 07:48:54 +00:00
|
|
|
i.stateLock.Lock()
|
|
|
|
defer i.stateLock.Unlock()
|
|
|
|
for key, info := range i.tasks {
|
|
|
|
fn(key.ClusterID, key.BuildID, info)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-19 08:55:27 +00:00
|
|
|
func (i *IndexNode) storeIndexFilesAndStatistic(ClusterID string, buildID UniqueID, fileKeys []string, serializedSize uint64, statistic *indexpb.JobInfo) {
|
2022-09-06 09:19:11 +00:00
|
|
|
key := taskKey{ClusterID: ClusterID, BuildID: buildID}
|
2022-08-25 07:48:54 +00:00
|
|
|
i.stateLock.Lock()
|
|
|
|
defer i.stateLock.Unlock()
|
|
|
|
if info, ok := i.tasks[key]; ok {
|
2022-10-19 08:55:27 +00:00
|
|
|
info.fileKeys = common.CloneStringList(fileKeys)
|
2022-08-25 07:48:54 +00:00
|
|
|
info.serializedSize = serializedSize
|
|
|
|
info.statistic = proto.Clone(statistic).(*indexpb.JobInfo)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *IndexNode) deleteTaskInfos(keys []taskKey) []*taskInfo {
|
|
|
|
i.stateLock.Lock()
|
|
|
|
defer i.stateLock.Unlock()
|
|
|
|
deleted := make([]*taskInfo, 0, len(keys))
|
|
|
|
for _, key := range keys {
|
|
|
|
info, ok := i.tasks[key]
|
|
|
|
if ok {
|
|
|
|
deleted = append(deleted, info)
|
|
|
|
delete(i.tasks, key)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return deleted
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *IndexNode) deleteAllTasks() []*taskInfo {
|
|
|
|
i.stateLock.Lock()
|
|
|
|
deletedTasks := i.tasks
|
|
|
|
i.tasks = make(map[taskKey]*taskInfo)
|
|
|
|
i.stateLock.Unlock()
|
|
|
|
|
|
|
|
deleted := make([]*taskInfo, 0, len(deletedTasks))
|
|
|
|
for _, info := range deletedTasks {
|
|
|
|
deleted = append(deleted, info)
|
|
|
|
}
|
|
|
|
return deleted
|
|
|
|
}
|