Files
zhub/zsub/zgroup.go
lxy 0aa0abb762 新增:延时事件持久化
git-svn-id: svn://47.119.165.148/zhub@101 e63fbceb-bcc3-4977-ac22-735b83d8d0f4
2021-02-06 08:10:01 +00:00

50 lines
814 B
Go

package zsub
import (
"sync"
"sync/atomic"
)
type ZGroup struct { // ZGroup
sync.Mutex
conns []*ZConn
offset int32
chMsg chan string // 组消息即时投递
ztopic *ZTopic // 所属topic
}
func (g *ZGroup) appendTo(c *ZConn) {
topic := g.ztopic.topic
// report subscribe topic check
if c.substoped[topic] != nil {
return
}
// create new goroutine consumer message
c.substoped[topic] = make(chan int, 0)
c.appendTo(g.conns)
go func() {
for {
select {
case msg, ok := <-g.chMsg:
if !ok {
return
}
err := c.send("message", topic, msg)
if err != nil { // 失败处理
g.chMsg <- msg
return
}
atomic.AddInt32(&g.offset, 1)
case <-c.stoped:
return
case <-c.substoped[topic]:
delete(c.substoped, topic)
return
}
}
}()
}