REST和RPC的联系和区别

RPC

RPC,也就是远程过程调用,简单来说也就是一台主机的一个程序远程的调用另一台主机的程序函数的过程。

  • 本地过程调用:调用函数直接通过调用目标函数,并传递相应的参数到结果就行,这一切调用过程都通过函数指针来完成。
  • 远程过程调用:上述过程操作隔离为客户端与服务端两个部分,客户端需要将本地
    参数转换为字节流,传递给服务器,同时通知服务器调用相对应的代码进行计算,同时根据远程调用的函数涉及到的输入输出进行相应参数的传递。与本地过程调用相比,远程过程调用新增了数据传递这一步,但其从使用上和本地过程调用并无较大差别

可以看到与本地过程调用相比,RPC的关键在于数据的序列化与数据的传递。这一步由于各个rpc框架的不同,其实现方式也各不相同。一般常见的数据序列化手段有json,xml,protobuf等,而数据的传输也有tcp,http协议等

REST

REST以业务为导向,更多的是规定了http域名与域名传递参数的格式,它定义了一组体系架构原则来限制http服务的借口规则,通过对http post/get方法使用的限定,使得整体的项目数据流通架构更清晰,更适用于web开发中服务的界定

两者对比

综合以上,REST更对的是通过对url的限定来实现客户端与服务端的通信沟通,使用起来接口清晰明确,具备良好的一致性和便捷性,在web开发中更为适用。RPC则不限制客户端与服务端的沟通的方式,沟通效率与实时性更高,更适合一些实时性要求高的场景。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值