微服务下跨语言 RPC 实现

作者: Anoyi | 来源:发表于2018-08-13 18:37 被阅读207次

Java 与 Java 之间互调

目前主流的 Java 开发框架 Spring Boot,为了更方便集成 gRPC,自己开发了 spring-boot-starter-grpc,仅需简单的几行配置即可使用。相关使用文档如下:

跨语言 RPC 理论基础

1、服务定义 (Service definition)

默认情况下,grpc 使用 protocol buffers 作为接口定义语言(IDL)来描述服务接口和消息结构。以下为 spring-boot-starter-grpc 中定义的通用的 IDL:

syntax = "proto3";

option java_package = "com.anoyi.rpc";
option java_outer_classname = "GrpcService";
option java_multiple_files = false;

// 定义通用的 Grpc 服务
service CommonService {
    // 处理请求
    rpc handle ( Request ) returns ( Response ) {}
}

// 定义通用的 Grpc 请求体
message Request {
    bytes request = 1;
}

// 定义通用的 Grpc 响应体
message Response {
    bytes response = 1;
}

文件地址:service.proto

grpc 提供了多种语言对此类 IDL 的支持,包括:C++C#DartGoJavaNode.jsObjective-CPHPPythonRuby

作为服务提供方,需要实现 CommonServicehandle 方法;作为服务调用方,直接使用 CommonServicehandle 方法即可。

2、序列化与反序列化 (serialize / deserialize)

上述 service.proto 文件中定义了请求体和响应体的数据类型为 bytes ,在多语言编程环境下,远程方法调用都需要将要发送的数据序列化为 bytes,将接收到的数据反序列化为所需的对象。

目前,grpc 支持的语言都支持了 JSON 文本和 XML 文本的解析,个人认为 JSON 比较简洁,所以优先考虑将请求体和响应体转为 JSON 字符串,然后中间层再做序列化和反序列化。

3、反射 (reflect)

上述序列化与反序列化解决了数据传输的问题,服务提供方接收到信息后就需要处理调用方的请求,以 Java 为例,调用远程方法时,会提供 类名方法名方法参数 等信息,有了这些信息,服务提供方就能通过反射调用该方法的具体实现。下面列举各种语言反射的实现:

此处未展示 Java 和 JavaScript 的反射机制,下文将以实例说明。

Java 与 JavaScript 之间互调

示例:服务提供方 (Node.js)、服务调用方(Java)

中间依赖 service.proto 定义的通用服务

相关文章

  • 微服务下跨语言 RPC 实现

    Java 与 Java 之间互调 目前主流的 Java 开发框架 Spring Boot,为了更方便集成 gRPC...

  • RPC详解&跨语言RPC实践

    本文将从大的框架层面来聊聊RPC原理和实现,既然叫跨语言RPC,也将以thrift为例讲讲跨语言RPC如何实现。在...

  • Apache Thrift - 可伸缩的跨语言服务开发框架

    Apache Thrift - 可伸缩的跨语言服务开发框架 RPC技术及实现简介 首先思考一下分布式系统中的 RP...

  • Thrift框架Demo

    简介 rpc框架,用于服务之间进行rpc通讯,跨语言,通过中间语言IDL来联系客户端和服务器。 helloworl...

  • 明星分分合合的洪荒点击量,微博Mesh服务化改造如何支撑?

    大家好,我今天的分享主要围绕以下几点,首先跟大家简要介绍一下微博服务化的演进过程,其次是微博自研跨语言RPC 框架...

  • Thrift简介

    thrift最初由Facebook研发,主要用于各个服务之间的RPC通信,支持跨语言,常用的语言 ActionSc...

  • RPC框架 之 Apach thrift

    Thrift 1,Apache Thrift 主要用于各个服务之间的RPC通信,支持跨语言,常用语言:C++, J...

  • thrift 简介一

    Thrift最初由Facebook研发,主要用于各个服务之间的RPC通信,支持跨语言,常用的语言比如C++, Ja...

  • Dubbo

    Dubbo(服务治理框架) RPC 各服务都要实现rpc协议,才能实现服务间的调用 rpc:远程过程调用协议,是一...

  • Thrift 开源多语言服务开发框架

    Thrift是什么? RPC服务框架,为了跨语言的服务开发。它是一个生成代码的工具。只需要依照IDL(Interf...

网友评论

    本文标题:微服务下跨语言 RPC 实现

    本文链接:https://www.haomeiwen.com/subject/rfjdbftx.html