Java中的gRPC – 阻塞/非阻塞存根

我正在尝试创建一个 java grpc客户端来与go中的服务器通信.我是grpc的新手所以遵循本教程 gRPC Java Tutorial.在这些示例中,它们指的是阻塞和非阻塞存根,它们似乎是从 github的其他地方导入的.

import io.grpc.examples.routeguide.RouteGuideGrpc.RouteGuideBlockingStub;
import io.grpc.examples.routeguide.RouteGuideGrpc.RouteGuideStub;
...
...    
blockingStub = RouteGuideGrpc.newBlockingStub(channel);
asyncStub = RouteGuideGrpc.newStub(channel);

但是我在他们的回购中找不到这些类.如果在编译.proto文件时它们是否已生成,我仍然对它们的用途感到朦胧?任何帮助/指针将不胜感激.谢谢.

解决方法

运行protoc编译器时会生成grpc存根类,并在proto文件中找到服务声明.存根类是客户端用于在服务端点上进行rpc调用的API.

这些存根有两种形式:阻塞和异步.

阻塞存根是同步的(阻止当前运行的线程)并确保在它上面调用的rpc调用在返回响应或引发异常之前不会返回.应该注意不要从UI线程调用阻塞存根上的rpc,因为这将导致无响应/ janky UI.

异步存根通过StreamObserver回调对象进行非阻塞rpc调用,其中响应是异步返回的.

有关更多信息,请参阅有关存根here的grpc文档.

相关文章

gRPC 前言 为什么使用gRPC 传输协议 传输效率 性能消耗 gRPC...
参考文章: 1. https://www.cnblogs.com/kaixinyufe...
今天给大家翻译一篇由ASP.NET首席开发工程师 "Jame...
上一篇文章我带着大家体验了一把《 "ASP.NET Core ...
早就听说ASP.NET Core 3.0中引入了gRPC的服务模板,正好趁着...
这篇笔记主要是记录学习历程而不是怎么用~,以及protobuffe...