1 Star 0 Fork 2

何吕 / volantmq

forked from JUMEI_ARCH / volantmq 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
flowControl.go 1.64 KB
一键复制 编辑 原始数据 按行查看 历史
Artur Troian 提交于 2017-08-24 18:53 . Rename messages to packet
package connection
import (
"errors"
"sync"
"sync/atomic"
"github.com/troian/surgemq/packet"
)
type packetsFlowControl struct {
counter uint64
quit chan struct{}
cond *sync.Cond
inUse map[packet.IDType]bool
sendQuota int32
preserveOrder bool
}
func newFlowControl(quit chan struct{}, preserveOrder bool) *packetsFlowControl {
return &packetsFlowControl{
inUse: make(map[packet.IDType]bool),
cond: sync.NewCond(new(sync.Mutex)),
quit: quit,
preserveOrder: preserveOrder,
}
}
func (s *packetsFlowControl) acquire() (packet.IDType, error) {
defer s.cond.L.Unlock()
s.cond.L.Lock()
if (s.preserveOrder && !atomic.CompareAndSwapInt32(&s.sendQuota, 0, 1)) ||
(atomic.AddInt32(&s.sendQuota, -1) == 0) {
s.cond.Wait()
select {
case <-s.quit:
return 0, errors.New("exit")
default:
}
}
var id packet.IDType
for count := 0; count <= 0xFFFF; count++ {
s.counter++
id = packet.IDType(s.counter)
if _, ok := s.inUse[id]; !ok {
s.inUse[id] = true
break
}
}
return id, nil
}
//func (s *packetsFlowControl) reAcquire(id message.IDType) error {
// defer s.lock.Unlock()
// s.lock.Lock()
//
// if (s.preserveOrder && !atomic.CompareAndSwapInt32(&s.sendQuota, 0, 1)) ||
// (atomic.AddInt32(&s.sendQuota, -1) == 0) {
// s.cond.Wait()
// select {
// case <-s.quit:
// return errors.New("exit")
// default:
// }
// }
//
// s.inUse[id] = true
//
// return nil
//}
func (s *packetsFlowControl) release(id packet.IDType) {
defer func() {
atomic.AddInt32(&s.sendQuota, -1)
s.cond.Signal()
}()
defer s.cond.L.Unlock()
s.cond.L.Lock()
delete(s.inUse, id)
}
Go
1
https://gitee.com/kaifazhe/volantmq.git
git@gitee.com:kaifazhe/volantmq.git
kaifazhe
volantmq
volantmq
v0.0.2-beta

搜索帮助