Files
zhub/zsub/zgroup.go
lxy fb93177de7 新增:重复订阅主题检查
git-svn-id: svn://47.119.165.148/zhub@100 e63fbceb-bcc3-4977-ac22-735b83d8d0f4
2021-02-05 03:48:58 +00:00

49 lines
813 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
}
c.substoped[topic] = make(chan int, 0)
c.appendTo(g.conns)
go func() { // create new goroutine consumer message
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
}
}
}()
}