Documentation ¶
Index ¶
- Constants
- Variables
- func CheckCollectionsQueryable(m *meta.Meta, targetMgr meta.TargetManagerInterface, ...) error
- func CheckLeaderAvailable(nodeMgr *session.NodeManager, leader *meta.LeaderView, ...) error
- func CheckNodeAvailable(nodeID int64, info *session.NodeInfo) error
- func CreateTestChannel(collection, node, version int64, channel string) *meta.DmChannel
- func CreateTestCollection(collection int64, replica int32) *meta.Collection
- func CreateTestLeaderView(id, collection int64, channel string, segments map[int64]int64, ...) *meta.LeaderView
- func CreateTestPartition(collection int64, partitionID int64) *meta.Partition
- func CreateTestReplica(id, collectionID int64, nodes []int64) *meta.Replica
- func CreateTestSchema() *schemapb.CollectionSchema
- func CreateTestSegment(collection, partition, segment, node, version int64, channel string) *meta.Segment
- func CreateTestSegmentInfo(collection, partition, segment int64, channel string) *datapb.SegmentInfo
- func FilterReleased[E interface{ ... }](elems []E, collections []int64) []E
- func FindMaxVersionSegments(segments []*meta.Segment) []*meta.Segment
- func GetPartitions(collectionMgr *meta.CollectionManager, collectionID int64) ([]int64, error)
- func GetShardLeaders(m *meta.Meta, targetMgr meta.TargetManagerInterface, ...) ([]*querypb.ShardLeadersList, error)
- func GetShardLeadersWithChannels(m *meta.Meta, targetMgr meta.TargetManagerInterface, ...) ([]*querypb.ShardLeadersList, error)
- func GroupNodesByReplica(replicaMgr *meta.ReplicaManager, collectionID int64, nodes []int64) map[int64][]int64
- func GroupPartitionsByCollection(partitions []*meta.Partition) map[int64][]*meta.Partition
- func GroupSegmentsByReplica(replicaMgr *meta.ReplicaManager, collectionID int64, segments []*meta.Segment) map[int64][]*meta.Segment
- func MergeDmChannelInfo(infos []*datapb.VchannelInfo) *meta.DmChannel
- func MergeMetaSegmentIntoSegmentInfo(info *querypb.SegmentInfo, segments ...*meta.Segment)
- func PackSegmentLoadInfo(segment *datapb.SegmentInfo, channelCheckpoint *msgpb.MsgPosition, ...) *querypb.SegmentLoadInfo
- func RecoverAllCollection(m *meta.Meta)
- func RecoverReplicaOfCollection(m *meta.Meta, collectionID typeutil.UniqueID)
- func SpawnReplicasWithRG(m *meta.Meta, collection int64, resourceGroups []string, replicaNumber int32, ...) ([]*meta.Replica, error)
- type CheckerType
Constants ¶
const ( SegmentCheckerName = "segment_checker" ChannelCheckerName = "channel_checker" BalanceCheckerName = "balance_checker" IndexCheckerName = "index_checker" LeaderCheckerName = "leader_checker" ManualBalanceName = "manual_balance" )
Variables ¶
var ( ErrGetNodesFromRG = errors.New("failed to get node from rg") ErrNoReplicaFound = errors.New("no replica found during assign nodes") ErrReplicasInconsistent = errors.New("all replicas should belong to same collection during assign nodes") ErrUseWrongNumRG = errors.New("resource group num can only be 0, 1 or same as replica number") )
Functions ¶
func CheckCollectionsQueryable ¶
func CheckCollectionsQueryable(m *meta.Meta, targetMgr meta.TargetManagerInterface, dist *meta.DistributionManager, nodeMgr *session.NodeManager) error
CheckCollectionsQueryable check all channels are watched and all segments are loaded for this collection
func CheckLeaderAvailable ¶
func CheckLeaderAvailable(nodeMgr *session.NodeManager, leader *meta.LeaderView, currentTargets map[int64]*datapb.SegmentInfo) error
In a replica, a shard is available, if and only if: 1. The leader is online 2. All QueryNodes in the distribution are online 3. The last heartbeat response time is within HeartbeatAvailableInterval for all QueryNodes(include leader) in the distribution 4. All segments of the shard in target should be in the distribution
func CreateTestChannel ¶
func CreateTestCollection ¶
func CreateTestCollection(collection int64, replica int32) *meta.Collection
func CreateTestLeaderView ¶
func CreateTestPartition ¶
func CreateTestReplica ¶
func CreateTestSchema ¶
func CreateTestSchema() *schemapb.CollectionSchema
func CreateTestSegment ¶
func CreateTestSegmentInfo ¶
func CreateTestSegmentInfo(collection, partition, segment int64, channel string) *datapb.SegmentInfo
func FilterReleased ¶
func GetPartitions ¶
func GetPartitions(collectionMgr *meta.CollectionManager, collectionID int64) ([]int64, error)
func GetShardLeaders ¶
func GetShardLeaders(m *meta.Meta, targetMgr meta.TargetManagerInterface, dist *meta.DistributionManager, nodeMgr *session.NodeManager, collectionID int64) ([]*querypb.ShardLeadersList, error)
func GetShardLeadersWithChannels ¶
func GetShardLeadersWithChannels(m *meta.Meta, targetMgr meta.TargetManagerInterface, dist *meta.DistributionManager, nodeMgr *session.NodeManager, collectionID int64, channels map[string]*meta.DmChannel, ) ([]*querypb.ShardLeadersList, error)
func GroupNodesByReplica ¶
func GroupNodesByReplica(replicaMgr *meta.ReplicaManager, collectionID int64, nodes []int64) map[int64][]int64
GroupNodesByReplica groups nodes by replica, returns ReplicaID -> NodeIDs
func GroupPartitionsByCollection ¶
GroupPartitionsByCollection groups partitions by collection, returns CollectionID -> Partitions
func GroupSegmentsByReplica ¶
func GroupSegmentsByReplica(replicaMgr *meta.ReplicaManager, collectionID int64, segments []*meta.Segment) map[int64][]*meta.Segment
GroupSegmentsByReplica groups segments by replica, returns ReplicaID -> Segments
func MergeDmChannelInfo ¶
func MergeDmChannelInfo(infos []*datapb.VchannelInfo) *meta.DmChannel
func MergeMetaSegmentIntoSegmentInfo ¶
func MergeMetaSegmentIntoSegmentInfo(info *querypb.SegmentInfo, segments ...*meta.Segment)
func PackSegmentLoadInfo ¶
func PackSegmentLoadInfo(segment *datapb.SegmentInfo, channelCheckpoint *msgpb.MsgPosition, indexes []*querypb.FieldIndexInfo) *querypb.SegmentLoadInfo
packSegmentLoadInfo packs SegmentLoadInfo for given segment, packs with index if withIndex is true, this fetch indexes from IndexCoord
func RecoverAllCollection ¶
RecoverAllCollectionrecovers all replica of all collection in resource group.
func RecoverReplicaOfCollection ¶
RecoverReplicaOfCollection recovers all replica of collection with latest resource group.
Types ¶
type CheckerType ¶
type CheckerType int32
const ( ChannelChecker CheckerType = iota + 1 SegmentChecker BalanceChecker IndexChecker LeaderChecker ManualBalance )
func (CheckerType) String ¶
func (s CheckerType) String() string