Hadoop 7days-02 HDFS的java接口和流程,Hadoop RPC

RPC:远程过程调用,

    不同于之前的socket编程,socket编程只是简单的信息的传递,而RPC涉及到不同机器之上的方法的调用。可以看做client得到了一个server的代理对象,可以根据该代理对象调用server上的进程。因此两个不同的进程可以调用。即远程过程调用(不同进程的方法调用)。

RPC是通过代理对象实现的,而JDK的动态代理要求Server和Client必须同时实现某个接口。

对于RPCServer:


上面,setProtocol里的参数是Server和Client共同实现的接口,setInstance里的参数是Server的对象,之后绑定地址和端口号。且其返回类型为Server类型。

对于RPCClient:


对于客户端,获得Server的代理对象,就可以调用Server的方法。其返回值为一泛型,第二个参数为versionID,所实现的接口中必须有该项,为long类型。

其实NameNode 和DataNode也是利用了上述的原理,作为Server运行在机器上,当Client和NameNode发生关系时,就相当于调用NameNode的方法。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值