Signed-off-by: arraykeys@gmail.com <arraykeys@gmail.com>

This commit is contained in:
arraykeys@gmail.com
2018-02-26 10:26:58 +08:00
parent 8dda32a599
commit 5e3f51a8b0
2 changed files with 49 additions and 1 deletions

View File

@ -15,13 +15,16 @@ import (
type MuxBridge struct { type MuxBridge struct {
cfg MuxBridgeArgs cfg MuxBridgeArgs
clientControlConns utils.ConcurrentMap clientControlConns utils.ConcurrentMap
router utils.ClientKeyRouter
} }
func NewMuxBridge() Service { func NewMuxBridge() Service {
return &MuxBridge{ b := &MuxBridge{
cfg: MuxBridgeArgs{}, cfg: MuxBridgeArgs{},
clientControlConns: utils.NewConcurrentMap(), clientControlConns: utils.NewConcurrentMap(),
} }
b.router = utils.NewClientKeyRouter(&b.clientControlConns, 50000)
return b
} }
func (s *MuxBridge) InitService() { func (s *MuxBridge) InitService() {
@ -118,6 +121,9 @@ func (s *MuxBridge) callback(inConn net.Conn, serverID, key string) {
if try == 0 { if try == 0 {
break break
} }
if key == "*" {
key = s.router.GetKey()
}
session, ok := s.clientControlConns.Get(key) session, ok := s.clientControlConns.Get(key)
if !ok { if !ok {
log.Printf("client %s session not exists for server stream %s", key, serverID) log.Printf("client %s session not exists for server stream %s", key, serverID)

View File

@ -773,3 +773,45 @@ func (cm *ConnManager) RemoveAll() {
cm.Remove(k) cm.Remove(k)
} }
} }
type ClientKeyRouter struct {
keyChan chan string
ctrl *ConcurrentMap
lock *sync.Mutex
}
func NewClientKeyRouter(ctrl *ConcurrentMap, size int) ClientKeyRouter {
return ClientKeyRouter{
keyChan: make(chan string, size),
ctrl: ctrl,
lock: &sync.Mutex{},
}
}
func (c *ClientKeyRouter) GetKey() string {
defer c.lock.Unlock()
c.lock.Lock()
if len(c.keyChan) == 0 {
EXIT:
for _, k := range c.ctrl.Keys() {
select {
case c.keyChan <- k:
default:
goto EXIT
}
}
}
for {
if len(c.keyChan) == 0 {
return "*"
}
select {
case key := <-c.keyChan:
if c.ctrl.Has(key) {
return key
}
default:
return "*"
}
}
}