39 lines
776 B
39 lines
776 B
3 years ago
|
package random
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"math/rand"
|
||
|
|
||
|
"github.com/go-kratos/kratos/v2/selector"
|
||
|
"github.com/go-kratos/kratos/v2/selector/node/direct"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
_ selector.Balancer = &Balancer{}
|
||
|
|
||
|
// Name is balancer name
|
||
|
Name = "random"
|
||
|
)
|
||
|
|
||
|
// Balancer is a random balancer.
|
||
|
type Balancer struct{}
|
||
|
|
||
|
// New random a selector.
|
||
|
func New() selector.Selector {
|
||
|
return &selector.Default{
|
||
|
Balancer: &Balancer{},
|
||
|
NodeBuilder: &direct.Builder{},
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Pick pick a weighted node.
|
||
|
func (p *Balancer) Pick(_ context.Context, nodes []selector.WeightedNode) (selector.WeightedNode, selector.DoneFunc, error) {
|
||
|
if len(nodes) == 0 {
|
||
|
return nil, nil, selector.ErrNoAvailable
|
||
|
}
|
||
|
cur := rand.Intn(len(nodes))
|
||
|
selected := nodes[cur]
|
||
|
d := selected.Pick()
|
||
|
return selected, d, nil
|
||
|
}
|