mirror of
https://github.com/duanhf2012/origin.git
synced 2026-02-04 06:54:45 +08:00
websocket client 重连缓冲区数据没有清空bug
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
package network
|
package network
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
@@ -32,6 +33,7 @@ type WebsocketClient struct {
|
|||||||
url string
|
url string
|
||||||
state int //0未连接状态 1正在重连 2连接状态
|
state int //0未连接状态 1正在重连 2连接状态
|
||||||
bwritemsg chan []byte
|
bwritemsg chan []byte
|
||||||
|
closer chan bool
|
||||||
slf IWebsocketClient
|
slf IWebsocketClient
|
||||||
timeoutsec time.Duration
|
timeoutsec time.Duration
|
||||||
|
|
||||||
@@ -39,6 +41,10 @@ type WebsocketClient struct {
|
|||||||
ping string
|
ping string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
MAX_WRITE_MSG = 10240
|
||||||
|
)
|
||||||
|
|
||||||
//Init ...
|
//Init ...
|
||||||
func (ws *WebsocketClient) Init(slf IWebsocketClient, strurl, strProxyPath string, timeoutsec time.Duration) error {
|
func (ws *WebsocketClient) Init(slf IWebsocketClient, strurl, strProxyPath string, timeoutsec time.Duration) error {
|
||||||
|
|
||||||
@@ -65,7 +71,6 @@ func (ws *WebsocketClient) Init(slf IWebsocketClient, strurl, strProxyPath strin
|
|||||||
}
|
}
|
||||||
|
|
||||||
ws.url = strurl
|
ws.url = strurl
|
||||||
ws.bwritemsg = make(chan []byte, 1000)
|
|
||||||
ws.ping = `ping`
|
ws.ping = `ping`
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@@ -94,8 +99,9 @@ func (ws *WebsocketClient) OnRun() error {
|
|||||||
time.Sleep(2 * time.Second)
|
time.Sleep(2 * time.Second)
|
||||||
ws.StartConnect()
|
ws.StartConnect()
|
||||||
} else if ws.state == 1 {
|
} else if ws.state == 1 {
|
||||||
ws.conn.Close()
|
|
||||||
ws.state = 0
|
ws.state = 0
|
||||||
|
close(ws.closer)
|
||||||
|
ws.conn.Close()
|
||||||
ws.slf.OnDisconnect()
|
ws.slf.OnDisconnect()
|
||||||
} else if ws.state == 2 {
|
} else if ws.state == 2 {
|
||||||
ws.conn.SetReadDeadline(time.Now().Add(ws.timeoutsec * time.Second))
|
ws.conn.SetReadDeadline(time.Now().Add(ws.timeoutsec * time.Second))
|
||||||
@@ -105,6 +111,7 @@ func (ws *WebsocketClient) OnRun() error {
|
|||||||
service.GetLogger().Printf(service.LEVER_WARN, "websocket client is disconnect [%s],information is %v", ws.url, err)
|
service.GetLogger().Printf(service.LEVER_WARN, "websocket client is disconnect [%s],information is %v", ws.url, err)
|
||||||
ws.conn.Close()
|
ws.conn.Close()
|
||||||
ws.state = 0
|
ws.state = 0
|
||||||
|
close(ws.closer)
|
||||||
ws.slf.OnDisconnect()
|
ws.slf.OnDisconnect()
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@@ -125,7 +132,8 @@ func (ws *WebsocketClient) StartConnect() error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
ws.closer = make(chan bool)
|
||||||
|
ws.bwritemsg = make(chan []byte, MAX_WRITE_MSG)
|
||||||
ws.state = 2
|
ws.state = 2
|
||||||
ws.slf.OnConnected()
|
ws.slf.OnConnected()
|
||||||
|
|
||||||
@@ -167,6 +175,11 @@ func (ws *WebsocketClient) writeMsg() error {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
select {
|
select {
|
||||||
|
case _, ok := <-ws.closer:
|
||||||
|
if ok == false {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
case <-timerC:
|
case <-timerC:
|
||||||
if ws.state == 2 {
|
if ws.state == 2 {
|
||||||
err := ws.WriteMessage([]byte(ws.ping))
|
err := ws.WriteMessage([]byte(ws.ping))
|
||||||
@@ -177,8 +190,8 @@ func (ws *WebsocketClient) writeMsg() error {
|
|||||||
ws.slf.OnDisconnect()
|
ws.slf.OnDisconnect()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case msg := <-ws.bwritemsg:
|
case msg, ok := <-ws.bwritemsg:
|
||||||
if ws.state == 2 {
|
if ok == true && ws.state == 2 {
|
||||||
ws.conn.SetWriteDeadline(time.Now().Add(ws.timeoutsec * time.Second))
|
ws.conn.SetWriteDeadline(time.Now().Add(ws.timeoutsec * time.Second))
|
||||||
err := ws.conn.WriteMessage(websocket.TextMessage, msg)
|
err := ws.conn.WriteMessage(websocket.TextMessage, msg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -201,7 +214,24 @@ func (ws *WebsocketClient) ReConnect() {
|
|||||||
|
|
||||||
//WriteMessage ...
|
//WriteMessage ...
|
||||||
func (ws *WebsocketClient) WriteMessage(msg []byte) error {
|
func (ws *WebsocketClient) WriteMessage(msg []byte) error {
|
||||||
|
if ws.closer == nil || ws.bwritemsg == nil {
|
||||||
|
service.GetLogger().Printf(service.LEVER_WARN, "WriteMessage data fail,websocket client is disconnect.")
|
||||||
|
return errors.New("riteMessage data fail,websocket client is disconnect.")
|
||||||
|
}
|
||||||
|
select {
|
||||||
|
case <-ws.closer:
|
||||||
|
service.GetLogger().Printf(service.LEVER_WARN, "WriteMessage data fail,websocket client is disconnect.")
|
||||||
|
return errors.New("riteMessage data fail,websocket client is disconnect.")
|
||||||
|
default:
|
||||||
|
if len(ws.bwritemsg) < MAX_WRITE_MSG {
|
||||||
ws.bwritemsg <- msg
|
ws.bwritemsg <- msg
|
||||||
|
} else {
|
||||||
|
service.GetLogger().Printf(service.LEVER_ERROR, "WriteMessage data fail,bwriteMsg is overload.")
|
||||||
|
return errors.New("WriteMessage data fail,bwriteMsg is overload.")
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user