谷歌开源 Kotlin 版本 gRPC

来源: OSCHINA
编辑:
2020-04-20 07:48:49

谷歌开源了 gRPC-Kotlin/JVM,让开发者可以在 Kotlin 项目中更方便地使用 gRPC,以更简单的方式构建可靠的网络连接服务。

gRPC 是谷歌开源的高性能、通用 RPC 框架,支持多种编程语言,包括 C++、Java、Objective-C、Python、Ruby、Go、C# 与 Node.js 等。gRPC 基于 Protocol Buffers,它面向移动和基于 HTTP/2 标准设计,带来诸如双向流、流控、头部压缩、单 TCP 连接上的多复用请求等特性。这些特性使得其在移动设备上表现更好,更省电且节省空间占用。

谷歌认为,将 gRPC 与世界上第二流行的 JVM 编程语言 Kotlin 结合,开发者可以构建从移动应用程序到云端微服务的一切。此项目构建在 gRPC 的 Java API 之上,提供了对 Kotlin 友好的 gRPC 类,支持 Kotlin 协程。

下面来看一个例子。首先需要一个 proto 定义,这是一个语言无关的服务接口定义:

message HelloRequest {
  string name = 1;
}

message HelloReply {
  string message = 1;
}

service Greeter {
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}

运行 gRPC Kotlin 生成器之后,能够以协程的形式实现服务:

private class HelloWorldService: GreeterCoroutineImplBase() {
 override suspend fun sayHello(request: HelloRequest) = HelloReply
     .newBuilder()
     .setMessage("Hello ${request.name}")
     .build()
}

并从客户端异步调用它:

val request = HelloRequest.newBuilder().setName(name).build()
val response = async { stub.sayHello(request) }
println("Received: ${response.await().message}")

协程非常适合用于异步编程,而 Kotlin 版本的 gRPC 则使它变得更容易。

开发者如果希望在自己的项目中使用 gRPC Kotlin,需要同时添加生成器和 grpc-java 配置。目前 gRPC Kotlin 仍处于测试阶段,初始版本为 0.1.1 版本

详细内容点此查看

展开阅读全文
精彩评论
gson序列化json还比较慢呢,说的好像你的项目瓶颈就在序列化这块呢。大厂出品,放心用就是
2020-04-21 01:14
9
举报
gRPC 性能差了些,灵活性也不太好,就是支持的语言多了点儿。
2020-04-20 10:43
2
举报
http://www.360doc.com/content/18/0719/21/9200790_771761124.shtml 性能只是一方面。
2020-04-20 18:32
1
举报
Thrift 性能大概是 gRPC 的 2.x 倍,而 Tars 性能大概是 gRPC 的 5 倍,这方面的文章比较多,可 Google 搜索。
2020-04-20 16:06
1
举报
能给下性能差的测评或者文章出处吗?最近想使用gRPC弄个项目。
2020-04-20 13:55
1
举报
12 收藏
分享
12 评论
12 收藏
分享
返回顶部
顶部