fix heartbeat error

This commit is contained in:
fatedier 2017-03-27 17:25:25 +08:00
parent 58d0d41501
commit 30aeaf968e
2 changed files with 6 additions and 1 deletions

View File

@ -218,7 +218,7 @@ func (ctl *Control) reader() {
return
} else {
ctl.Warn("read error: %v", err)
continue
return
}
} else {
ctl.readCh <- m
@ -262,10 +262,13 @@ func (ctl *Control) manager() {
select {
case <-hbSend.C:
// send heartbeat to server
ctl.Debug("send heartbeat to server")
ctl.sendCh <- &msg.Ping{}
case <-hbCheck.C:
if time.Since(ctl.lastPong) > time.Duration(config.ClientCommonCfg.HeartBeatTimeout)*time.Second {
ctl.Warn("heartbeat timeout")
// let reader() stop
ctl.conn.Close()
return
}
case rawMsg, ok := <-ctl.readCh:
@ -302,6 +305,7 @@ func (ctl *Control) manager() {
ctl.Info("[%s] start proxy success", m.ProxyName)
case *msg.Pong:
ctl.lastPong = time.Now()
ctl.Debug("receive heartbeat from server")
}
}
}

View File

@ -318,6 +318,7 @@ func (ctl *Control) manager() {
ctl.sendCh <- resp
case *msg.Ping:
ctl.lastPing = time.Now()
ctl.conn.Debug("receive heartbeat")
ctl.sendCh <- &msg.Pong{}
}
}