Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
milvus
milvus
提交
bc62ca1f
M
milvus
项目概览
milvus
/
milvus
大约 1 年 前同步成功
通知
261
Star
22476
Fork
2472
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
milvus
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
bc62ca1f
编写于
8月 09, 2022
作者:
C
congqixia
提交者:
GitHub
8月 09, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Release collection resources when all partition released (#18569)
Signed-off-by:
N
Congqi Xia
<
congqi.xia@zilliz.com
>
上级
d62381af
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
128 addition
and
17 deletion
+128
-17
internal/querynode/task.go
internal/querynode/task.go
+72
-15
internal/querynode/task_test.go
internal/querynode/task_test.go
+56
-2
未找到文件。
internal/querynode/task.go
浏览文件 @
bc62ca1f
...
...
@@ -31,6 +31,7 @@ import (
"github.com/milvus-io/milvus/internal/proto/internalpb"
queryPb
"github.com/milvus-io/milvus/internal/proto/querypb"
"github.com/milvus-io/milvus/internal/util/funcutil"
"github.com/milvus-io/milvus/internal/util/typeutil"
)
type
task
interface
{
...
...
@@ -594,6 +595,7 @@ func (r *releaseCollectionTask) Execute(ctx context.Context) error {
r
.
node
.
metaReplica
.
removeExcludedSegments
(
r
.
req
.
CollectionID
)
r
.
node
.
queryShardService
.
releaseCollection
(
r
.
req
.
CollectionID
)
r
.
node
.
ShardClusterService
.
releaseCollection
(
r
.
req
.
CollectionID
)
err
=
r
.
node
.
metaReplica
.
removeCollection
(
r
.
req
.
CollectionID
)
if
err
!=
nil
{
return
err
...
...
@@ -607,29 +609,84 @@ func (r *releaseCollectionTask) Execute(ctx context.Context) error {
// releasePartitionsTask
func
(
r
*
releasePartitionsTask
)
Execute
(
ctx
context
.
Context
)
error
{
log
.
Info
(
"Execute release partition task"
,
zap
.
Any
(
"collectionID"
,
r
.
req
.
CollectionID
),
zap
.
Any
(
"partitionIDs"
,
r
.
req
.
PartitionIDs
))
zap
.
Int64
(
"collectionID"
,
r
.
req
.
GetCollectionID
()
),
zap
.
Int64s
(
"partitionIDs"
,
r
.
req
.
GetPartitionIDs
()
))
_
,
err
:=
r
.
node
.
metaReplica
.
getCollectionByID
(
r
.
req
.
CollectionID
)
coll
,
err
:=
r
.
node
.
metaReplica
.
getCollectionByID
(
r
.
req
.
CollectionID
)
if
err
!=
nil
{
return
fmt
.
Errorf
(
"release partitions failed, collectionID = %d, err = %s"
,
r
.
req
.
CollectionID
,
err
)
// skip error if collection not found, do clean up job below
log
.
Warn
(
"failed to get collection for release partitions"
,
zap
.
Int64
(
"collectionID"
,
r
.
req
.
GetCollectionID
()),
zap
.
Int64s
(
"partitionIDs"
,
r
.
req
.
GetPartitionIDs
()))
}
log
.
Info
(
"start release partition"
,
zap
.
Any
(
"collectionID"
,
r
.
req
.
CollectionID
))
log
.
Info
(
"start release partition"
,
zap
.
Int64
(
"collectionID"
,
r
.
req
.
GetCollectionID
()),
zap
.
Int64s
(
"partitionIDs"
,
r
.
req
.
GetPartitionIDs
()
))
for
_
,
id
:=
range
r
.
req
.
PartitionIDs
{
// remove partition from streaming and historical
hasPartition
:=
r
.
node
.
metaReplica
.
hasPartition
(
id
)
if
hasPartition
{
err
:=
r
.
node
.
metaReplica
.
removePartition
(
id
)
if
err
!=
nil
{
// not return, try to release all partitions
log
.
Warn
(
err
.
Error
())
// shall be false if coll is nil
releaseAll
:=
r
.
isAllPartitionsReleased
(
coll
)
if
releaseAll
{
// set release time
log
.
Info
(
"set release time"
,
zap
.
Int64
(
"collectionID"
,
r
.
req
.
CollectionID
))
coll
.
setReleaseTime
(
r
.
req
.
Base
.
Timestamp
,
true
)
// remove all flow graphs of the target collection
vChannels
:=
coll
.
getVChannels
()
vDeltaChannels
:=
coll
.
getVDeltaChannels
()
r
.
node
.
dataSyncService
.
removeFlowGraphsByDMLChannels
(
vChannels
)
r
.
node
.
dataSyncService
.
removeFlowGraphsByDeltaChannels
(
vDeltaChannels
)
// remove all tSafes of the target collection
for
_
,
channel
:=
range
vChannels
{
r
.
node
.
tSafeReplica
.
removeTSafe
(
channel
)
}
for
_
,
channel
:=
range
vDeltaChannels
{
r
.
node
.
tSafeReplica
.
removeTSafe
(
channel
)
}
log
.
Info
(
"Release tSafe in releaseCollectionTask"
,
zap
.
Int64
(
"collectionID"
,
r
.
req
.
CollectionID
),
zap
.
Strings
(
"vChannels"
,
vChannels
),
zap
.
Strings
(
"vDeltaChannels"
,
vDeltaChannels
),
)
r
.
node
.
metaReplica
.
removeExcludedSegments
(
r
.
req
.
CollectionID
)
r
.
node
.
queryShardService
.
releaseCollection
(
r
.
req
.
CollectionID
)
r
.
node
.
ShardClusterService
.
releaseCollection
(
r
.
req
.
CollectionID
)
err
=
r
.
node
.
metaReplica
.
removeCollection
(
r
.
req
.
CollectionID
)
if
err
!=
nil
{
log
.
Warn
(
"failed to remove collection"
,
zap
.
Int64
(
"collectionID"
,
r
.
req
.
GetCollectionID
()),
zap
.
Int64s
(
"partitionIDs"
,
r
.
req
.
GetPartitionIDs
()),
zap
.
Error
(
err
))
}
}
else
{
for
_
,
id
:=
range
r
.
req
.
PartitionIDs
{
// remove partition from streaming and historical
hasPartition
:=
r
.
node
.
metaReplica
.
hasPartition
(
id
)
if
hasPartition
{
err
:=
r
.
node
.
metaReplica
.
removePartition
(
id
)
if
err
!=
nil
{
// not return, try to release all partitions
log
.
Warn
(
err
.
Error
())
}
}
}
}
log
.
Info
(
"Release partition task done"
,
zap
.
Any
(
"collectionID"
,
r
.
req
.
CollectionID
),
zap
.
Any
(
"partitionIDs"
,
r
.
req
.
PartitionIDs
))
zap
.
Int64
(
"collectionID"
,
r
.
req
.
CollectionID
),
zap
.
Int64s
(
"partitionIDs"
,
r
.
req
.
PartitionIDs
))
return
nil
}
func
(
r
*
releasePartitionsTask
)
isAllPartitionsReleased
(
coll
*
Collection
)
bool
{
if
coll
==
nil
{
return
false
}
if
len
(
r
.
req
.
GetPartitionIDs
())
<
len
(
coll
.
partitionIDs
)
&&
len
(
coll
.
partitionIDs
)
>
0
{
return
false
}
parts
:=
make
(
typeutil
.
UniqueSet
)
for
_
,
partID
:=
range
r
.
req
.
GetPartitionIDs
()
{
parts
.
Insert
(
partID
)
}
return
parts
.
Contain
(
coll
.
partitionIDs
...
)
}
internal/querynode/task_test.go
浏览文件 @
bc62ca1f
...
...
@@ -21,6 +21,9 @@ import (
"testing"
"time"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/milvus-io/milvus/internal/mq/msgstream"
"github.com/milvus-io/milvus/internal/mq/msgstream/mqwrapper/rmq"
"github.com/milvus-io/milvus/internal/proto/commonpb"
...
...
@@ -30,7 +33,6 @@ import (
"github.com/milvus-io/milvus/internal/proto/schemapb"
"github.com/milvus-io/milvus/internal/util/funcutil"
"github.com/milvus-io/milvus/internal/util/typeutil"
"github.com/stretchr/testify/assert"
)
func
TestTask_watchDmChannelsTask
(
t
*
testing
.
T
)
{
...
...
@@ -746,6 +748,28 @@ func TestTask_releasePartitionTask(t *testing.T) {
assert
.
NoError
(
t
,
err
)
})
t
.
Run
(
"test isAllPartitionsReleased"
,
func
(
t
*
testing
.
T
)
{
node
,
err
:=
genSimpleQueryNode
(
ctx
)
assert
.
NoError
(
t
,
err
)
task
:=
releasePartitionsTask
{
req
:
genReleasePartitionsRequest
(),
node
:
node
,
}
coll
,
err
:=
node
.
metaReplica
.
getCollectionByID
(
defaultCollectionID
)
require
.
NoError
(
t
,
err
)
assert
.
False
(
t
,
task
.
isAllPartitionsReleased
(
nil
))
assert
.
True
(
t
,
task
.
isAllPartitionsReleased
(
coll
))
node
.
metaReplica
.
addPartition
(
defaultCollectionID
,
-
1
)
assert
.
False
(
t
,
task
.
isAllPartitionsReleased
(
coll
))
node
.
metaReplica
.
removePartition
(
defaultPartitionID
)
node
.
metaReplica
.
removePartition
(
-
1
)
assert
.
True
(
t
,
task
.
isAllPartitionsReleased
(
coll
))
})
t
.
Run
(
"test execute"
,
func
(
t
*
testing
.
T
)
{
node
,
err
:=
genSimpleQueryNode
(
ctx
)
assert
.
NoError
(
t
,
err
)
...
...
@@ -776,7 +800,37 @@ func TestTask_releasePartitionTask(t *testing.T) {
assert
.
NoError
(
t
,
err
)
err
=
task
.
Execute
(
ctx
)
assert
.
Error
(
t
,
err
)
assert
.
NoError
(
t
,
err
)
})
t
.
Run
(
"test execute no partition"
,
func
(
t
*
testing
.
T
)
{
node
,
err
:=
genSimpleQueryNode
(
ctx
)
assert
.
NoError
(
t
,
err
)
task
:=
releasePartitionsTask
{
req
:
genReleasePartitionsRequest
(),
node
:
node
,
}
err
=
node
.
metaReplica
.
removePartition
(
defaultPartitionID
)
assert
.
NoError
(
t
,
err
)
err
=
task
.
Execute
(
ctx
)
assert
.
NoError
(
t
,
err
)
})
t
.
Run
(
"test execute non-exist partition"
,
func
(
t
*
testing
.
T
)
{
node
,
err
:=
genSimpleQueryNode
(
ctx
)
assert
.
NoError
(
t
,
err
)
req
:=
genReleasePartitionsRequest
()
req
.
PartitionIDs
=
[]
int64
{
-
1
}
task
:=
releasePartitionsTask
{
req
:
req
,
node
:
node
,
}
err
=
task
.
Execute
(
ctx
)
assert
.
NoError
(
t
,
err
)
})
t
.
Run
(
"test execute remove deltaVChannel"
,
func
(
t
*
testing
.
T
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录