全称是Remote Procedure Call
,远程过程调用。直观的理解就是,通过网络来请求服务,不用知晓底层网络协议的细节。
RPC
支持的格式很多,比如XML
格式,JSON
格式等等。
这种介绍,一般都是皮毛,去看维基百科上的介绍会更加深入一些:
在分布式计算中,远程过程调用就是当计算机程序运行过程中导致一个子进程在不同的地址空间运行,通常是另一台电脑,通过网络共享地址空间。这时候,这个子进程就像是在自己的电脑上运行的一样,不用编程者显式处理编码细节,毕竟进程运行在别的电脑了嘛。
这其实就是C/S架构的交互形式,发起调用的是客户端,执行子进程的是服务端。一般来说,这种实现是通过请求-响应的消息传递机制。
另外,RPC也是IPC的一种形式。所谓IPC是指Inter-Process Communication,进程间通信。
JSON是一种轻量级的数据交换格式,它可以表示数值、字符串、序列及名/值对集合。
JSON-RPC是一种无状态的,轻量级的远程程序调用协议。
如何使用JSON-RPC
JSON-RPC协议中的客户端一般是为了向远程系统请求执行某个方法。客户端向实现了JSON-RPC协议的服务端发送请求,多个输入参数能够通过数组或者对象传递到远程方法,这个远程方法也能返回多个输出数据,具体是什么,当然要看具体的方法实现。
所有的传输都是单个对象,用JSON格式进行序列化。请求包含三个特定属性:
method
,方法,是等待调用的远程方法名,字符串类型params
,参数,对象类型或者是数组,向远程方法传递的多个参数值id
,任意类型值,用于和最后的响应进行匹配,也就是这里设定多少,后面响应里这个值也设定为相同的响应的接收者必须能够给出所有请求以正确的响应。响应也有三个属性:
result
,结果,是方法的返回值,如果方法执行时出现了错误,那么这个值必须为空error
,错误,当出现错误时,返回一个特定的错误编码,没有错误就为空值id
,就是请求带的那个id
值,用于匹配需要注意到,有一些场景下,是不用返回值的,比如只对客户端进行通知,由于不用对请求的id
进行匹配,所以这个id
就是不必要的,置空或者直接不要了。
END.
参考链接:
https://www.jianshu.com/p/49cd5c9a1664
http://cw.hubwiz.com/card/c/ethereum-json-rpc-api/
https://en.wikipedia.org/wiki/Remote_procedure_call