java实现hadoopRPC协议,模拟namenode和datanode的通信

一、概念

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
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值