From 8d0f6fb7c43aa07e822fca07d07980fd7f9403ac Mon Sep 17 00:00:00 2001 From: UUBulb <35923940+uubulb@users.noreply.github.com> Date: Wed, 23 Oct 2024 12:55:10 +0800 Subject: [PATCH] add path check for multiplexer (#451) --- cmd/dashboard/main.go | 11 ++++++----- cmd/dashboard/rpc/rpc.go | 4 +--- 2 files changed, 7 insertions(+), 8 deletions(-) diff --git a/cmd/dashboard/main.go b/cmd/dashboard/main.go index 72b7fcb..6822a50 100644 --- a/cmd/dashboard/main.go +++ b/cmd/dashboard/main.go @@ -123,20 +123,20 @@ func main() { grpcHandler := rpc.ServeRPC() httpHandler := controller.ServeWeb() - mixedHandler := newHTTPandGRPCMux(httpHandler, grpcHandler) + muxHandler := newHTTPandGRPCMux(httpHandler, grpcHandler) http2Server := &http2.Server{} - http1Server := &http.Server{Handler: h2c.NewHandler(mixedHandler, http2Server), ReadHeaderTimeout: time.Second * 5} + muxServer := &http.Server{Handler: h2c.NewHandler(muxHandler, http2Server), ReadHeaderTimeout: time.Second * 5} go dispatchReportInfoTask() if err := graceful.Graceful(func() error { log.Println("NEZHA>> Dashboard::START", singleton.Conf.ListenPort) - return http1Server.Serve(l) + return muxServer.Serve(l) }, func(c context.Context) error { log.Println("NEZHA>> Graceful::START") singleton.RecordTransferHourlyUsage() log.Println("NEZHA>> Graceful::END") - return l.Close() + return muxServer.Shutdown(c) }); err != nil { log.Printf("NEZHA>> ERROR: %v", err) } @@ -159,7 +159,8 @@ func dispatchReportInfoTask() { func newHTTPandGRPCMux(httpHandler http.Handler, grpcHandler http.Handler) http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { - if r.ProtoMajor == 2 && strings.HasPrefix(r.Header.Get("content-type"), "application/grpc") { + if r.ProtoMajor == 2 && r.Header.Get("Content-Type") == "application/grpc" && + strings.HasPrefix(r.URL.Path, "/"+proto.NezhaService_ServiceDesc.ServiceName) { grpcHandler.ServeHTTP(w, r) return } diff --git a/cmd/dashboard/rpc/rpc.go b/cmd/dashboard/rpc/rpc.go index 7c97554..b55d9b9 100644 --- a/cmd/dashboard/rpc/rpc.go +++ b/cmd/dashboard/rpc/rpc.go @@ -1,8 +1,6 @@ package rpc import ( - "net/http" - "google.golang.org/grpc" "github.com/naiba/nezha/model" @@ -11,7 +9,7 @@ import ( "github.com/naiba/nezha/service/singleton" ) -func ServeRPC() http.Handler { +func ServeRPC() *grpc.Server { server := grpc.NewServer() rpcService.NezhaHandlerSingleton = rpcService.NewNezhaHandler() pb.RegisterNezhaServiceServer(server, rpcService.NezhaHandlerSingleton)