mirror of
https://github.com/duanhf2012/origin.git
synced 2026-03-13 03:27:36 +08:00
优化websocket服务
This commit is contained in:
@@ -61,7 +61,7 @@ func (ws *CTest) RPC_LogTicker2(args *CTestData, quo *CTestData) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ws *CTest) Http_LogTicker2(request *sysservice.HttpRequest, resp *sysservice.HttpRespone) error {
|
func (ws *CTest) HTTP_LogTicker2(request *sysservice.HttpRequest, resp *sysservice.HttpRespone) error {
|
||||||
|
|
||||||
resp.Respone = "hello world!"
|
resp.Respone = "hello world!"
|
||||||
return nil
|
return nil
|
||||||
@@ -111,8 +111,8 @@ func main() {
|
|||||||
var receiver CMessageReceiver
|
var receiver CMessageReceiver
|
||||||
wsservice := sysservice.NewWSServerService("/ws", 1314, &receiver, false)
|
wsservice := sysservice.NewWSServerService("/ws", 1314, &receiver, false)
|
||||||
test := NewCTest(0)
|
test := NewCTest(0)
|
||||||
httpserver := sysservice.NewHttpServerService(80)
|
httpserver := sysservice.NewHttpServerService(9120)
|
||||||
server.SetupService(wsservice, test, httpserver)
|
server.SetupService(test, httpserver, wsservice)
|
||||||
|
|
||||||
server.Init()
|
server.Init()
|
||||||
server.Start()
|
server.Start()
|
||||||
|
|||||||
@@ -4,8 +4,11 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"sync"
|
"sync"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/gorilla/mux"
|
||||||
"github.com/gorilla/websocket"
|
"github.com/gorilla/websocket"
|
||||||
|
"github.com/gotoxu/cors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type IWebsocketServer interface {
|
type IWebsocketServer interface {
|
||||||
@@ -39,14 +42,11 @@ type WebsocketServer struct {
|
|||||||
bEnableCompression bool
|
bEnableCompression bool
|
||||||
locker sync.Mutex
|
locker sync.Mutex
|
||||||
messageReciver IMessageReceiver
|
messageReciver IMessageReceiver
|
||||||
|
|
||||||
|
httpserver *http.Server
|
||||||
}
|
}
|
||||||
|
|
||||||
func (slf *WebsocketServer) wsHandler(w http.ResponseWriter, r *http.Request) {
|
func (slf *WebsocketServer) wsHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
/*if r.Header.Get("Origin") != "http://"+r.Host {
|
|
||||||
http.Error(w, "Origin not allowed", 403)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
conn, err := websocket.Upgrade(w, r, w.Header(), 1024, 1024)
|
conn, err := websocket.Upgrade(w, r, w.Header(), 1024, 1024)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
http.Error(w, "Could not open websocket connection", http.StatusBadRequest)
|
http.Error(w, "Could not open websocket connection", http.StatusBadRequest)
|
||||||
@@ -83,14 +83,24 @@ func (slf *WebsocketServer) Init(pattern string, port uint16, messageReciver IMe
|
|||||||
slf.mapClient = make(map[uint64]*WSClient)
|
slf.mapClient = make(map[uint64]*WSClient)
|
||||||
slf.messageReciver = messageReciver
|
slf.messageReciver = messageReciver
|
||||||
|
|
||||||
http.HandleFunc(slf.pattern, slf.wsHandler)
|
//http.HandleFunc(slf.pattern, slf.wsHandler)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (slf *WebsocketServer) startListen() {
|
func (slf *WebsocketServer) startListen() {
|
||||||
address := fmt.Sprintf(":%d", slf.port)
|
|
||||||
err := http.ListenAndServe(address, nil)
|
listenPort := fmt.Sprintf(":%d", slf.port)
|
||||||
|
|
||||||
|
slf.httpserver = &http.Server{
|
||||||
|
Addr: listenPort,
|
||||||
|
Handler: slf.initRouterHandler(),
|
||||||
|
ReadTimeout: 10 * time.Second,
|
||||||
|
WriteTimeout: 10 * time.Second,
|
||||||
|
MaxHeaderBytes: 1 << 20,
|
||||||
|
}
|
||||||
|
|
||||||
|
err := slf.httpserver.ListenAndServe()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("%v", err)
|
fmt.Printf("http.ListenAndServe(%d, nil) error\n", slf.port)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -121,3 +131,18 @@ func (slf *WebsocketServer) SendMsg(clientid uint64, messageType int, msg []byte
|
|||||||
func (slf *WebsocketServer) Stop() {
|
func (slf *WebsocketServer) Stop() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (slf *WebsocketServer) initRouterHandler() http.Handler {
|
||||||
|
r := mux.NewRouter()
|
||||||
|
/*r.HandleFunc("/{server:[a-zA-Z0-9]+}/{method:[a-zA-Z0-9]+}", func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
slf.wsHandler(w, r)
|
||||||
|
})
|
||||||
|
*/
|
||||||
|
r.HandleFunc(slf.pattern, func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
slf.wsHandler(w, r)
|
||||||
|
})
|
||||||
|
|
||||||
|
cors := cors.AllowAll()
|
||||||
|
//return cors.Handler(gziphandler.GzipHandler(r))
|
||||||
|
return cors.Handler(r)
|
||||||
|
}
|
||||||
|
|||||||
@@ -277,9 +277,16 @@ func (server *Server) register(rcvr interface{}, name string, prefix string, use
|
|||||||
return errors.New(str)
|
return errors.New(str)
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, dup := server.serviceMap.LoadOrStore(sname, s); dup {
|
//将已经注册的消息加载
|
||||||
return errors.New("rpc: service already defined: " + sname)
|
svci, ok := server.serviceMap.Load(sname)
|
||||||
|
if ok {
|
||||||
|
svc := svci.(*service)
|
||||||
|
for key, value := range svc.method {
|
||||||
|
s.method[key] = &methodType{method: value.method, ArgType: value.ArgType, ReplyType: value.ReplyType}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
server.serviceMap.Store(sname, s)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user