A tour of gRPC:04 - gRPC unary call 一元调用
data:image/s3,"s3://crabby-images/c761d/c761d0824454c082fee0bc23c4a5ade08a9db089" alt="A tour of gRPC:04 - gRPC unary call 一元调用"
在上一篇中,我们尝试了 proto 的序列化功能,并尝试进行了跨语言的序列化。而在本篇中,我们将尝 试实现一个简单的 gRPC 一元调用(unary call),通过 client 调用 server 的创建方法创建一个 Laptop 对 象,并存储在 server 的内存中,并同样尝试跨语言的调用。
go unary call
1. 编写一个 laptop_service.proto,让 proto 帮助我们生成 stub
data:image/s3,"s3://crabby-images/b3d2a/b3d2aa4ff160556bf9e6defe0dc1bbfdeb23f6f8" alt=""
该 proto 包含三个部分
CreateLaptopRequest (创建请求)
CreateLaptopResponse (创建响应)
LaptopService(laptop 相关服务) · CreateLaptop (包括请求参数和返回参数)
2. 运行 make gen 将该服务进行生成 laptop_service.pb.go
3. 由于本次重点是 grpc 不是数据库存储,这里使用内存存储数据,新建一个 service 包编写一个 laptop_store.go 进行解耦。
data:image/s3,"s3://crabby-images/4a2d3/4a2d3873cf7d8727b233dba961184ef8561524bd" alt=""
4. 编写 laptop 服务类 laptop_server.go 作为服务端的实现
data:image/s3,"s3://crabby-images/3ce4f/3ce4f8843dfabff83e7be8e5ebd5a1384a6e3bfc" alt=""
5. 编写 laptop_server_test.go 作为 server 的测试类
data:image/s3,"s3://crabby-images/ed6f6/ed6f6047bb275ea007df46dcf7a20f048e9d48a6" alt=""
我们来用这个单元测试,测试一下 server 端的创建方法是否正常的运行了。可以看到
有 id、无 id、非法 id、重复 id 的情况均符合测试预期
data:image/s3,"s3://crabby-images/8b73a/8b73a91695cb72a09276765012d62071b5e189ed" alt=""
测试结果运行正常。
6. 编写 laptop_client_test.go 作为 client 的测试类
data:image/s3,"s3://crabby-images/6e26a/6e26a349c978d02a5fca0c703ed3047560916213" alt=""
运行测试,成功启动了 server 并通过 client 的调用创建了一个 laptop
data:image/s3,"s3://crabby-images/7c60f/7c60f88d08d68440f0e6160c455525651671c169" alt=""
7. 好了,接下来我们为 client 和 server 各编写一个启动类
a. main/client/main.go 作为 client 的启动类
data:image/s3,"s3://crabby-images/d2318/d23189467fa7c32dcd54880ba5a2ac87c32704ff" alt=""
b. main/server/main.go 作为 client 的启动类
data:image/s3,"s3://crabby-images/16c22/16c2298aa2f84cc9971ac95a938a852dbbfb115d" alt=""
c. 修改 Makefile 增加 client 和 server 的快捷启动
data:image/s3,"s3://crabby-images/4665e/4665e1fb8906d9ff90fff43eab8e87f65daf1658" alt=""
8.运行服务端、再运行客户端,修改 clien 创建 laptop 的 id 内容,进行如下测试
client 携带 id 【成功】
client 不携带 id 【成功】
client 携带非法 id 【失败】
client 携带重复 id 【失败】
data:image/s3,"s3://crabby-images/10579/10579c762af123c6855494c2b9a831051743d71f" alt=""
运行结果均符合预期。
Java unary call
1. 拷⻉之前在 go 项目中编写的 laptop_service.proto 并生成代码
2. 同 go 由于这里先不使用数据库(专注于 grpc)所以编写一个 LaptopStore 接口 和一个 InMemoryLaptopStore 实现类,用于解耦。
a. LaptopStore interface
data:image/s3,"s3://crabby-images/015f1/015f196ab5cb70687d9b377f765632cd6c9a1a04" alt=""
b. InMemoryLaptopStore 实现类
data:image/s3,"s3://crabby-images/9c9dd/9c9dda2cdf6ff91728bb879ff2d1252fa2ab9b61" alt=""
3. 接着在 server 包下编写 LaptopServer 服务类
data:image/s3,"s3://crabby-images/9a297/9a29706a57ada490316310fed3e0e5ba5f3cd518" alt=""
4. 在 service 包下编写 LaptopClient 作为 client 的启动类
data:image/s3,"s3://crabby-images/f06cb/f06cb68c0fdcba5c4c985e0457cd5bb7ee7e26ef" alt=""
5. 在 service 包下编写 LaptopServer 作为 server 的启动类
data:image/s3,"s3://crabby-images/befac/befacdc76b7990c2cbbc8ec0bed2b9b3a0c3a062" alt=""
6. 同样编写一个服务端的单元测试类 LaptopServerTest
data:image/s3,"s3://crabby-images/36759/36759ef1a5c3384ae36e8ee49ba130b48623784b" alt=""
data:image/s3,"s3://crabby-images/2cf96/2cf96ad7b62f550a69b1039e062d81ddd2fd7c84" alt=""
测试的结果符合预期
好了,接下来我们同 golang 项目一样,运行服务端、再运行客户端,修改 clien 创建 laptop 的 id 内容, 进行如下测试:client 携带 id 【成功】、client 不携带 id 【成功】、client 携带非法 id 【失败】client 携 带重复 id 【失败】
测试结果同上,这里就不进行展示了。
跨语言的 unary call 测试
我们先启动 Java 的 Server 再运行 golang 的 client,同样进行上述的测试:client 携带 id 【成功】、client 不携带 id 【成功】、client 携带非法 id 【失败】client 携带重复 id 【失败】
data:image/s3,"s3://crabby-images/c0430/c043036b38352ae22ef0b4da153fc66c2a7c9387" alt=""
测试的结果符合预期。
我们不妨再反过来测试一下,使用 golang 的 server 和 Java 的 client
data:image/s3,"s3://crabby-images/a7699/a769933a01c51701800d6e566d4d618552e8757f" alt=""
data:image/s3,"s3://crabby-images/e6d68/e6d68b09844b9aaed415889d251aa9fa7a164be8" alt=""
data:image/s3,"s3://crabby-images/8c628/8c6285c7af780ba7022751cd5ff2dc8fafa5a11c" alt=""
data:image/s3,"s3://crabby-images/83415/83415183f56bd4d6a16d4d01e0daa9076797521c" alt=""
data:image/s3,"s3://crabby-images/1ca00/1ca001b92df576ff21b513ddef354d7e49f4304a" alt=""
测试的结果同样符合预期,没有任何问题。在本篇中,我们实现了 gRPC 中的 unary call 并且初步尝试了 gRPC 的跨语言调用能力。
data:image/s3,"s3://crabby-images/65467/654679bbf9110f01f4e0b16d8fbc145331d361ea" alt=""
data:image/s3,"s3://crabby-images/4bb63/4bb6307d48e0f7916e036734c9e256d0cef26367" alt=""
data:image/s3,"s3://crabby-images/57c0c/57c0cd29b62644abe165c3f877c040dd5ca3fbd0" alt=""
版权声明: 本文为 InfoQ 作者【BUG侦探】的原创文章。
原文链接:【http://xie.infoq.cn/article/270fa2f7bab914be26e89b585】。文章转载请联系作者。
评论