duancashi1362 2017-02-24 14:33
浏览 739

grpc客户端实现如何同时管理更多请求?

I'm using grpc as IPC in a new software that I'm building but I came across this question: the grpc Client implantation in Go is synchronous or asynchronous?
Surfing on internet I discover that the C++ has both implementation but in Go there is lack of documentation about this feature (apart an issue on GitHub).
For this reason I start inspecting the Client code and I found that the client request is made by the invoke function (here the code) and seems that is running synchronously. For this reason I'm supposing that instead of using a global client and then pass to the struct that use the grpc functions I should create a client for each request to prevent a synchronous behaviour.
e.g. Instead of:

type Foo struct {
    ClientA *grpc.Client
}
type Bar struct {
    ClientB *grpc.Client
}
//Other stuff
client := createNewClient() //This function return a *grpc client 
foo := Foo{client}
bar := Bar{client}

I should create a new client for each function of Foo and Bar struct for executing calls not thread blocking. Is it correct?

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
    • ¥15 C# datagridview 单元格显示进度及值
    • ¥15 thinkphp6配合social login单点登录问题
    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 虚心请教几个问题,小生先有礼了
    • ¥30 截图中的mathematics程序转换成matlab