新增:延时事件持久化
git-svn-id: svn://47.119.165.148/zhub@101 e63fbceb-bcc3-4977-ac22-735b83d8d0f4
This commit is contained in:
36
zsub/zsub.go
36
zsub/zsub.go
@@ -4,17 +4,18 @@ import (
|
||||
"bufio"
|
||||
"log"
|
||||
"net"
|
||||
"os"
|
||||
"strconv"
|
||||
"strings"
|
||||
"sync"
|
||||
"time"
|
||||
"zhub/conf"
|
||||
)
|
||||
|
||||
var (
|
||||
zsub = ZSub{
|
||||
topics: make(map[string]*ZTopic),
|
||||
timers: make(map[string]*ZTimer),
|
||||
delays: make(map[string]*time.Timer),
|
||||
delays: make(map[string]*ZDelay),
|
||||
}
|
||||
)
|
||||
|
||||
@@ -22,7 +23,7 @@ type ZSub struct {
|
||||
sync.RWMutex
|
||||
topics map[string]*ZTopic
|
||||
timers map[string]*ZTimer
|
||||
delays map[string]*time.Timer
|
||||
delays map[string]*ZDelay
|
||||
}
|
||||
|
||||
type ZConn struct { //ZConn
|
||||
@@ -190,8 +191,11 @@ func (c *ZConn) appendTo(arr []*ZConn) []*ZConn {
|
||||
*/
|
||||
func ServerStart(addr string) {
|
||||
|
||||
// 加载定时调度服务
|
||||
zsub.reloadTimerConfig()
|
||||
conf.GetStr("data.dir", "data")
|
||||
|
||||
// 重新加载[定时、延时]
|
||||
go zsub.reloadTimerConfig()
|
||||
go zsub.reloadDelay()
|
||||
|
||||
// 启动服务监听
|
||||
listen, err := net.Listen("tcp", addr)
|
||||
@@ -200,19 +204,6 @@ func ServerStart(addr string) {
|
||||
}
|
||||
log.Printf("zhub started listen on: %s \n", addr)
|
||||
|
||||
// 启动消息监听处理
|
||||
go func() {
|
||||
for {
|
||||
v, ok := <-chanMessages
|
||||
if !ok {
|
||||
break
|
||||
}
|
||||
|
||||
// 事件消费
|
||||
msgAccept(v)
|
||||
}
|
||||
}()
|
||||
|
||||
for {
|
||||
conn, err := listen.Accept()
|
||||
if err != nil {
|
||||
@@ -264,7 +255,12 @@ func (s *ZSub) acceptHandler(c *ZConn) {
|
||||
continue
|
||||
}
|
||||
|
||||
// 接收消息 zdb fixme: 细节暴露太多
|
||||
chanMessages <- Message{Conn: c, Rcmd: rcmd}
|
||||
msgAccept(Message{Conn: c, Rcmd: rcmd})
|
||||
}
|
||||
}
|
||||
|
||||
func (s *ZSub) shutdown() {
|
||||
s.saveDelay()
|
||||
s.Lock()
|
||||
os.Exit(0)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user