Hadoop3:RPC通信原理及简单案例实现

一、场景介绍

我们知道,Hadoop中存在多种服务,那么,服务之间是如何通信的了?
比如,DN和NN之间如何通信?
这里,实际上是通过RPC实现进程间通信的了。

RPC属于Java网络编程范畴
需要编写客户端和服务端
底层实现是NIO
一般RPC框架的使用,需要配合服务注册中心组件使用。比如zookeeper,nacos
客户端通过zookeeper,拿到服务端的IP、PORT、method等参数
然后,本地实现远程服务调用,就类似调用本地方法一样简洁。
比较成功的RPC框架有:Dubbo、WebSocket、gRPC、OpenFeign

二、案例

1、需求

模拟RPC的客户端、服务端、通信协议三者如何工作的
在这里插入图片描述

2、代码

接口RPCProtocol

package com.atguigu.rpc;

public interface RPCProtocol {
	long versionID = 666;
	void mkdirs(String path);
}

服务端NNServer

package com.atguigu.rpc;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.ipc.RPC;
import org.apache.hadoop.ipc.Server;

import java.io.IOException;

public class NNServer implements RPCProtocol {
	@Override
	public void mkdirs(String path) {
		System.out.println("服务端,创建路径" + path);
	}

	public static void main(String[] args) throws IOException {

		Server server = new RPC.Builder(new Configuration())
				.setBindAddress("localhost")
				.setPort(8888)
				.setProtocol(RPCProtocol.class)
				.setInstance(new NNServer())
				.build();

		System.out.println("服务器开始工作");

		server.start();
	}
}

客户端HDFSClient

package com.atguigu.rpc;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.ipc.RPC;

import java.io.IOException;
import java.net.InetSocketAddress;

public class HDFSClient {
	public static void main(String[] args) throws IOException {
		RPCProtocol client = RPC.getProxy(
				RPCProtocol.class,
				RPCProtocol.versionID,
				new InetSocketAddress("localhost", 8888),
				new Configuration());

		System.out.println("我是客户端");

		client.mkdirs("/input");
	}
}

3、测试

启动服务端
在这里插入图片描述
查看进程
在这里插入图片描述
运行客户端
在这里插入图片描述
服务端方法被执行
在这里插入图片描述

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-18 07:08:01       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-18 07:08:01       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-18 07:08:01       57 阅读
  4. Python语言-面向对象

    2024-07-18 07:08:01       68 阅读

热门阅读

  1. Redis数据结构--跳跃表 Skip List

    2024-07-18 07:08:01       20 阅读
  2. feign 接口调用下载接口技巧

    2024-07-18 07:08:01       22 阅读
  3. 简述机器学习中常用的一些统计量

    2024-07-18 07:08:01       23 阅读
  4. VSCODE 驯服日记(二)对MPE的格式进行调整

    2024-07-18 07:08:01       21 阅读
  5. 建造者模式例题

    2024-07-18 07:08:01       20 阅读
  6. Electron 配置macOS平台的安装图标

    2024-07-18 07:08:01       22 阅读
  7. jQuery 语法

    2024-07-18 07:08:01       21 阅读
  8. 71、Flink 的 Hybrid Source 详解

    2024-07-18 07:08:01       19 阅读