Files
zhub/zsub/zgroup.go
lxy bb3802f0aa 修改:广播消息未成功发送bug
git-svn-id: svn://47.119.165.148/zhub@113 e63fbceb-bcc3-4977-ac22-735b83d8d0f4
2021-03-04 07:00:14 +00:00

55 lines
901 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) {
c.Lock()
defer c.Unlock()
topic := g.ztopic.topic
// report subscribe topic check
if c.substoped[topic] != nil {
return
}
// create new goroutine consumer message
unsubChan := make(chan int, 0)
c.substoped[topic] = unsubChan
g.conns = 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 <-unsubChan:
c.Lock()
defer c.Unlock()
delete(c.substoped, topic)
return
}
}
}()
}