gRPC服务器通过以太网的响应时间长

时间:2019-03-12 13:46:10

标签: performance go server grpc

我正在用C#编写的gRPC客户端和一堆服务器(用c ++,C#,rust and go编写)测试客户端-服务器连接。当我在本地进行测试时,一切正常(平均GO响应约为0.12ms),但是当我在本地网络上进行测试时,它会变得非常慢,例如非常慢。每个请求平均时间为40毫秒! 需要明确的是:我正在使用一个具有最简单连接的简单HelloWorld原型。其他服务器每次请求大约需要1毫秒,但Go大约需要40毫秒。

我的Go服务器代码:

 package main

import (
    "context"
    pb "descriptions"
    "log"
    "net"

    "google.golang.org/grpc"
)

type server struct{}

// SayHello implements helloworld.GreeterServer
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
    //log.Printf("Received: %v", in.Name)
    return &pb.HelloReply{Message: ""}, nil
}

func main() {
    //  lis, err := net.Listen("tcp", port)
    lis, err := net.Listen("tcp", "0.0.0.0:50051")
    if err != nil {
        log.Fatalf("failed to listen: %v", err)
    }
    s := grpc.NewServer()
    log.Printf("Server listening on: " + lis.Addr().String())
    pb.RegisterGreeterServer(s, &server{})
    if err := s.Serve(lis); err != nil {
        log.Fatalf("failed to serve: %v", err)
    }
}

我不怀疑这是客户端问题,因为它可以与其他服务器一起使用。有人和golang有相同的观点吗?请告诉我! 我也在想这是否可能像HTTP 1.1问题,但gRPC支持HTTP2,因此我怀疑在运行此代码时已使用它。

1 个答案:

答案 0 :(得分:0)

根据基准here,Go和C ++不应有太大的区别(通过以太网)。您能否在grpc-go仓库https://github.com/grpc/grpc-go/issues/new中提出问题?如果您可以提供有关客户端工作方式的更多上下文,这将非常有帮助。谢谢!