mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-06 17:18:35 +08:00
issue: #33285 - add two grpc resolver (by session and by streaming coord assignment service) - add one grpc balancer (by serverID and roundrobin) - add lazy conn to avoid block by first service discovery - add some utility function for streaming service Signed-off-by: chyezh <chyezh@outlook.com>
30 lines
898 B
Go
30 lines
898 B
Go
package discoverer
|
|
|
|
import (
|
|
"context"
|
|
|
|
"google.golang.org/grpc/resolver"
|
|
|
|
"github.com/milvus-io/milvus/pkg/util/typeutil"
|
|
)
|
|
|
|
// Discoverer is the interface for the discoverer.
|
|
// Do not promise
|
|
// 1. concurrent safe.
|
|
// 2. the version of discovery may be repeated or decreasing. So user should check the version in callback.
|
|
type Discoverer interface {
|
|
// NewVersionedState returns a lowest versioned state.
|
|
NewVersionedState() VersionedState
|
|
|
|
// Discover watches the service discovery on these goroutine.
|
|
// 1. Call the callback when the discovery is changed, and block until the discovery is canceled or break down.
|
|
// 2. Discover should always send the current state first and then block.
|
|
Discover(ctx context.Context, cb func(VersionedState) error) error
|
|
}
|
|
|
|
// VersionedState is the state with version.
|
|
type VersionedState struct {
|
|
Version typeutil.Version
|
|
State resolver.State
|
|
}
|