mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-05-03 09:20:50 -05:00
5ed57cc09a
* bump dependencies Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de> * bump reva and add config options Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de> --------- Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
57 lines
1.0 KiB
Go
57 lines
1.0 KiB
Go
package selector
|
|
|
|
import (
|
|
"math/rand"
|
|
"sync"
|
|
"time"
|
|
|
|
"go-micro.dev/v4/registry"
|
|
)
|
|
|
|
func init() {
|
|
rand.Seed(time.Now().UnixNano())
|
|
}
|
|
|
|
// Random is a random strategy algorithm for node selection.
|
|
func Random(services []*registry.Service) Next {
|
|
nodes := make([]*registry.Node, 0, len(services))
|
|
|
|
for _, service := range services {
|
|
nodes = append(nodes, service.Nodes...)
|
|
}
|
|
|
|
return func() (*registry.Node, error) {
|
|
if len(nodes) == 0 {
|
|
return nil, ErrNoneAvailable
|
|
}
|
|
|
|
i := rand.Int() % len(nodes)
|
|
return nodes[i], nil
|
|
}
|
|
}
|
|
|
|
// RoundRobin is a roundrobin strategy algorithm for node selection.
|
|
func RoundRobin(services []*registry.Service) Next {
|
|
nodes := make([]*registry.Node, 0, len(services))
|
|
|
|
for _, service := range services {
|
|
nodes = append(nodes, service.Nodes...)
|
|
}
|
|
|
|
var i = rand.Int()
|
|
var mtx sync.Mutex
|
|
|
|
return func() (*registry.Node, error) {
|
|
if len(nodes) == 0 {
|
|
return nil, ErrNoneAvailable
|
|
}
|
|
|
|
mtx.Lock()
|
|
node := nodes[i%len(nodes)]
|
|
i++
|
|
mtx.Unlock()
|
|
|
|
return node, nil
|
|
}
|
|
}
|