| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 | 
							- package protocol
 
- import (
 
- 	"sync"
 
- )
 
- type ServerList struct {
 
- 	sync.RWMutex
 
- 	servers []*ServerSpec
 
- }
 
- func NewServerList() *ServerList {
 
- 	return &ServerList{}
 
- }
 
- func (v *ServerList) AddServer(server *ServerSpec) {
 
- 	v.Lock()
 
- 	defer v.Unlock()
 
- 	v.servers = append(v.servers, server)
 
- }
 
- func (v *ServerList) Size() uint32 {
 
- 	v.RLock()
 
- 	defer v.RUnlock()
 
- 	return uint32(len(v.servers))
 
- }
 
- func (v *ServerList) GetServer(idx uint32) *ServerSpec {
 
- 	v.RLock()
 
- 	defer v.RUnlock()
 
- 	for {
 
- 		if idx >= uint32(len(v.servers)) {
 
- 			return nil
 
- 		}
 
- 		server := v.servers[idx]
 
- 		if !server.IsValid() {
 
- 			v.RemoveServer(idx)
 
- 			continue
 
- 		}
 
- 		return server
 
- 	}
 
- }
 
- // Private: Visible for testing.
 
- func (v *ServerList) RemoveServer(idx uint32) {
 
- 	n := len(v.servers)
 
- 	v.servers[idx] = v.servers[n-1]
 
- 	v.servers = v.servers[:n-1]
 
- }
 
- type ServerPicker interface {
 
- 	PickServer() *ServerSpec
 
- }
 
- type RoundRobinServerPicker struct {
 
- 	sync.Mutex
 
- 	serverlist *ServerList
 
- 	nextIndex  uint32
 
- }
 
- func NewRoundRobinServerPicker(serverlist *ServerList) *RoundRobinServerPicker {
 
- 	return &RoundRobinServerPicker{
 
- 		serverlist: serverlist,
 
- 		nextIndex:  0,
 
- 	}
 
- }
 
- func (v *RoundRobinServerPicker) PickServer() *ServerSpec {
 
- 	v.Lock()
 
- 	defer v.Unlock()
 
- 	next := v.nextIndex
 
- 	server := v.serverlist.GetServer(next)
 
- 	if server == nil {
 
- 		next = 0
 
- 		server = v.serverlist.GetServer(0)
 
- 	}
 
- 	next++
 
- 	if next >= v.serverlist.Size() {
 
- 		next = 0
 
- 	}
 
- 	v.nextIndex = next
 
- 	return server
 
- }
 
 
  |