一、概念
RPC全称为Remote Procedure Call,远程进程/过程调用,是IPC的一种。
而IPC(Inter-Process Communication 进程间通信)分为了RPC和LPC(Local Process Call 本地进程间调用)。
RPC是hadoop中提供的框架,所以如果自己设计一个RPC框架,必须要引入hadoop相关的依赖。
二、原理简介
RPC作用和RMI(remote method invocation 远程方法调用),webservice、thrift服务类似。
RPC底层实现是基于TCP/IP协议来完成,是一个由服务端和客户端组成的应用,也就是说客户端携带请求参数向服务端发起请求,服务端接收到相关请求之后,进行处理,并将处理结果返回给客户端。
三、业务场景:
服务端和客户端,来模拟hadoop中NameNode和DataNode之间的心跳的过程。
四、代码实现
代码结构:
1、client
1.1包依赖
1.2代码实现:
2、protocol
2.1定义协议规范
2.2协议实现
2.2.1包依赖
2.2.2代码实现
注意:两张图是一个协议实现
2.3server
五、执行及结果展示
1、执行顺序:
先开启server,server启动成功后再去启动client
server成功启动标志:
2、执行效果
namenode
datanode