如何在 grpc 中进行 payload 压缩?

How to do payload compression in grpc?

我正在开发一个基于 grpc 的应用程序,其中请求数据可能高达 500KB,响应可能更大,所以我想压缩数据。我很难在 grpc 中找到 documents/examples 如何做到这一点。 clientContext 中的 set_compression_algorithm 有什么作用?我必须在服务器端设置一些东西吗?

或者我应该忘记 grpc 上的压缩,而自己对 protobuf 消息执行 compression/decompression into/out?

grpc::ClientContext::set_compression_algorithm方法选择用于客户端调用的算法,即从客户端发送到服务器的数据。

在服务器端,您可以通过 grpc::ServerBuilder::SetCompressionOptions(参见https://github.com/grpc/grpc/blob/master/include/grpc++/server_builder.h),它允许您:

  1. Select 服务器假定的压缩算法。默认情况下,启用所有算法。
  2. Select所有服务器响应默认使用哪种压缩算法(前提是对等客户端支持它。如果不支持,将以未压缩的方式发送响应)。

对于服务器端的一次性呼叫响应,您可以使用 grpc::ServerContext::set_compression_algorithmgrpc::ServerContext::set_compression_level。建议使用后者,因为它会根据客户端保证支持的请求压缩级别选择最佳算法。

我会在接下来的几天里整理出 hello-world 风格的例子。我已经创建了一个问题来跟踪这个:https://github.com/grpc/grpc/issues/6297 随时 ping 那里。我还实现了一些低级日志记录以显示一些压缩统计信息,以便你们能够断言压缩确实有效(否则一切都是完全透明的)。