performance - gRPC 服务器在以太网上的长响应时间
问题描述
我正在使用用 C# 编写的 gRPC 客户端和一堆服务器(用 c++、C#、rust 和 go 编写)测试客户端-服务器连接。当我在本地对其进行测试时,一切正常(平均 GO 响应大约为 0.12 毫秒),但是当我通过本地网络对其进行测试时,它变得非常慢,就像非常慢一样。每个请求的平均时间为 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,所以我怀疑它在运行此代码时已经使用过。
解决方案
根据这里的基准,Go 和 C++ 不应该有这么大的差异(通过以太网)。您能否在 grpc-go 存储库https://github.com/grpc/grpc-go/issues/new中提出问题?如果您可以提供有关客户端如何工作的更多上下文,这将非常有帮助。谢谢!
推荐阅读
- javascript - 需要使用正则表达式匹配排除 1M 记录,以获得具有最佳算法的代码流
- django - 如何检查 Flask 中修改了表单的哪些字段?
- mysql - vb.net 缓存数据库表
- java - 创建名为“webSecurityConfig”的 bean 时出错,因为当我尝试将其自动装配到 WebSecurityConfig 时,UserService Bean 不存在
- javascript - 如何从选定的li中获取文本值并使用js将其传递给另一个li中的输入
- spring - 在 1.4.5 中升级到 Spring Boot 2.1.3 后阅读文档时如何让 @TypeAlias 工作
- log4j - 如何在 log4j 属性文件中获取上下文路径?
- asynchronous - 类内的离子基本功能未完全执行
- swift - swift中的hitTest()用法
- sql - 如何在SQL中属性不同的行中随机选择一行?