HDFS源码(一)

Hadoop RPC框架原理

RPC(Remote Procedure Call,远程过程调用)是一种通过网络从远程计算机程序上请求服务而不需要了解底层网络技术的协议,通过RPC 能让应用层可以像调用本地方法一样调用远程方法。Hadoop中各个节点之间的通信就是通过RPC 进行通信。

RPC 采用Client/Server模式,请求程序就是Client客户端,服务提供程序就是Server服务端。客户端首先发送带参数的调用请求到服务器,然后等待服务器的响应,在服务器端,一旦有调用请求到达,服务提供程序会执行请求,计算结果,并向客户端发送响应信息,然后等待下一个调用请求,最终,客户端成功接收服务器发回的响应信息,一次远程调用完成。

Rpc工作原理图如下:

Client Function:客户端请求程序,可以像调用本地方法一样调用 Client Stub程序,也能接受Stub程序的响应信息。

Client Stub:客户端Stub程序,当客户端调用时会通过通信模块将信息发送给服务器,同时会等待服务器的响应信息。

socket:网络通信模块,用于传输RPC请求和响应。

Server Stub:服务端Stub程序,会接收客户端发送的请求和参数,根据响应信息触发对应的服务程序,然后将结果返回给客户端。

Server Function:服务端服务程序,会接受服务端Stub程序的调用请求并执行对应的逻辑返回结果。

HadoopRPC实现方式类似上图,代码位于hadoop-common中的org.apache.hadoop.ipc包下,HadoopRPC由3个类组成:RPC、Client和Server,这里不再深入查看相关源码,这里我们通过简单的例子来模拟RPC客户端和服务端通信。

定义接口协议(Protocol)及实现

RPC通信中有Client和Server端,由于在客户端可以像调用本地方法一样调用远程服务端方法并能解析做出响应,我们可以把这些方法抽象到一个接口中形成统一的接口协议。即:接口协议是一种"结构层次的协议",通过定义一组接口和方法来规范客户端和服务端之间的通信,我们可以把接口和接口中的方法称为协议,客户端和服务端只要实现这些接口中的方法就可以进行通信。如下图示:

创建并启动Server服务

定义类创建并启动RPC Server服务:

java 复制代码
/**
 * RPC Server
 */
public class RpcServer {

    public static void main(String[] args) throws IOException {
        //创建 RPC 框架
        RPC.Builder builder = new RPC.Builder(new Configuration());

        //绑定地址
        builder.setBindAddress("localhost");

        //绑定端口
        builder.setPort(8888);

        //绑定协议
        builder.setProtocol(RpcProtocol.class);

        //调用协议实现类
        builder.setInstance(new RpcProtocolImpl());

        //创建RPC Server 服务
        RPC.Server server = builder.build();

        //启动RPC Server 服务
        server.start();

        System.out.println("服务端启动成功~");
    }
}

创建Client服务调用远程服务

NameNode启动源码

启动NameNode HttpServer

加载fsimage和editslog

创建NameNode RpcServer并启动

检测集群是否处于安全模式

相关推荐
Francek Chen1 小时前
【大数据存储与管理】云数据库:02 云数据库产品
大数据·数据库·分布式·云计算·云数据库
2601_957780841 小时前
AI智能体时代:为什么HTML正在取代Markdown成为新一代输出标准
大数据·前端·人工智能·gpt·html·claude
乐迪信息1 小时前
乐迪信息:智慧港口安全,船舶AI视觉检测实现主动预警
大数据·人工智能·安全·计算机视觉·目标跟踪·视觉检测
shong_12291 小时前
企业培训考试系统多端统一管理解决方案
大数据
captain_AIouo1 小时前
全方位降本增效,Captain AI重构OZON运营成本结构
大数据·人工智能·经验分享·重构·aigc
SZLSDH1 小时前
专项治理场景下,数字孪生IOC的架构适配逻辑:以智慧河湖监管为例
java·大数据·架构·数据可视化
好赞科技1 小时前
2026医院预约小程序前五款高口碑产品:革新医疗便捷体验
大数据
容器魔方2 小时前
Karmada 用户组再迎新成员 | GMI Cloud 正式加入!
大数据·云原生·容器·华为云·云计算
青岛前景互联信息技术有限公司12 小时前
OpenClaw 重构智慧消防:AI时代的平台融合实践
大数据·人工智能