首页 > 解决方案 > 使用 nginx 的 gRPC 负载平衡比直接使用慢得多

问题描述

我正在使用 grpc-go 并想使用 nginx 进行负载平衡,但我不明白为什么 grpc_pass 会给出更糟糕的结果?

基准测试:

upstream "go_grpc" {
     server 127.0.0.1:10000;
}
server {
         listen 11000;
         proxy_pass go_grpc;
}

在 5 秒内处理了 10,000 个请求

通过流{}:

upstream "go_grpc" {
     server 127.0.0.1:10000;
}
server {
         listen 11000 http2;
         location / {
             grpc_pass grpc://go_grpc;
         }
}

在 10 秒内处理 10,000 个请求(长 2 倍)

标签: gonginxgrpchttp2

解决方案


推荐阅读