Go语言之GRPC

作者: 灰常出色 | 来源:发表于2020-06-15 12:10 被阅读0次

    RPC:远程调用框架(Remote Procedure Call),

    远程调用原理:

    比如 A (client) 调用 B (server) 提供的remoteAdd方法:

    首先A与B之间建立一个TCP连接;

    然后A把需要调用的方法名(这里是remoteAdd)以及方法参数(10, 20)序列化成字节流发送出去;

    B接受A发送过来的字节流,然后反序列化得到目标方法名,方法参数,接着执行相应的方法调用(可能是localAdd)并把结果30返回;A接受远程调用结果,输出30。

    RPC框架就是把我刚才说的这几点些细节给封装起来,给用户暴露简单友好的API使用。

    RPC与Socket的区别:

    RPC(远程过程调用)采用客户机/服务器模式实现两个进程之间相互通信。socket是RPC经常采用的通信手段之一,RPC是在Socket的基础上实现的,它比socket需要更多的网络和系统资源。除了Socket,RPC还有其他的通信方法,比如:http、操作系统自带的管道等技术来实现对于远程程序的调用。

    RPC与REST的区别:

    REST API 和 RPC 都是在 Server端 把一个个函数封装成接口暴露出去,以供 Client端 调用,不过 REST API 是基于 HTTP协议的,REST致力于通过http协议中的POST/GET/PUT/DELETE等方法和一个可读性强的URL来提供一个http请求。而 RPC 则可以不基于 HTTP协议。

    因此,如果是后端两种语言互相调用,用 RPC 可以获得更好的性能(省去了 HTTP 报头等一系列东西),应该也更容易配置。

    详细参考:Go语言之GRPC

    相关文章

      网友评论

        本文标题:Go语言之GRPC

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