go-zero/rpcx/internal/balancer/roundrobin/roundrobin.go

65 lines
1.2 KiB
Go
Raw Normal View History

2020-08-04 11:59:39 +08:00
package roundrobin
2020-07-30 20:09:45 +08:00
import (
2020-07-30 22:56:13 +08:00
"context"
2020-08-04 11:59:39 +08:00
"fmt"
2020-07-31 16:20:13 +08:00
"math/rand"
"sync"
"time"
2020-07-30 22:56:13 +08:00
2020-07-30 20:09:45 +08:00
"google.golang.org/grpc/balancer"
"google.golang.org/grpc/balancer/base"
2020-07-30 22:56:13 +08:00
"google.golang.org/grpc/resolver"
2020-07-30 20:09:45 +08:00
)
2020-08-04 11:59:39 +08:00
const Name = "zero_rr"
2020-07-30 20:09:45 +08:00
func init() {
2020-08-04 11:59:39 +08:00
balancer.Register(newRoundRobinBuilder())
2020-07-30 20:09:45 +08:00
}
type roundRobinPickerBuilder struct {
}
2020-08-04 11:59:39 +08:00
func newRoundRobinBuilder() balancer.Builder {
2020-07-30 20:09:45 +08:00
return base.NewBalancerBuilder(Name, new(roundRobinPickerBuilder))
}
2020-07-30 22:56:13 +08:00
func (b *roundRobinPickerBuilder) Build(readySCs map[resolver.Address]balancer.SubConn) balancer.Picker {
2020-07-31 16:20:13 +08:00
rand.Seed(time.Now().UnixNano())
picker := &roundRobinPicker{
index: rand.Int(),
}
for addr, conn := range readySCs {
picker.conns = append(picker.conns, &subConn{
addr: addr,
conn: conn,
})
}
return picker
2020-07-30 22:56:13 +08:00
}
type roundRobinPicker struct {
2020-07-31 16:20:13 +08:00
conns []*subConn
index int
lock sync.Mutex
2020-07-30 22:56:13 +08:00
}
func (p *roundRobinPicker) Pick(ctx context.Context, info balancer.PickInfo) (
conn balancer.SubConn, done func(balancer.DoneInfo), err error) {
2020-08-04 11:59:39 +08:00
fmt.Println(p.conns)
2020-07-31 16:20:13 +08:00
p.lock.Lock()
defer p.lock.Unlock()
p.index = (p.index + 1) % len(p.conns)
return p.conns[p.index].conn, func(info balancer.DoneInfo) {
}, nil
}
type subConn struct {
addr resolver.Address
conn balancer.SubConn
2020-07-30 20:09:45 +08:00
}