考察Hadoop的底层rpc通信(一)

##简介
IPC:inter process communication 即进程间通信
RPC: remote procedure call 即远程过程调用
首先,我们通过一张图来了解Hadoop中的IPC与RPC:
这里写图片描述
IPC是进程间通信的过程,RPC作为远程过程的调用,必定会涉及到IPC通信
远程过程调用,指调用服务器上的方法,所以业务真正的是执行在服务器上的;客户端通过网络间通信,与远程服务器打交道,本身是没有进行实现的(所以在服务器端有相关的程序进行实现)
在本文中,将通过Hadoop提供的相关API,用Java程序来实现服务器端和客户端,模拟这种通信机制。
在实现程序之前,先通过下图来了解程序的实现流程:
这里写图片描述
##程序实现
创建java程序
客户端和服务器端
创建接口HelloWorldService.java

public interface HelloWorldService extends VersionedProtocol{
	static final long versionID = 1;
	public String sayHello(String msg);
}

实现接口

import java.io.IOException;
import org.apache.hadoop.ipc.ProtocolSignature;

public class HelloWorldServiceImpl implements HelloWorldService {

	public long getProtocolVersion(String protocol, long clientVersion) throws IOException {
		return 1;
	}

	public ProtocolSignature getProtocolSignature(String protocol, long clientVersion, int clientMethodsHash)
			throws IOException {
		try {
			return ProtocolSignature.getProtocolSignature(protocol, clientVersion);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		return null;
	}

	public String sayHello(String msg) {
		System.out.println(msg);
		return "hello" + msg;
	}
}

创建MyServer服务器端

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

/**
 * 服务器端
 */
public class MyServer {
	public static void main(String[] args) {
		try {
			Configuration conf = new Configuration();
			Server server = new RPC.Builder(conf)
					//设置协议
					.setProtocol(HelloWorldService.class)
					//设置实现类
					.setInstance(new HelloWorldServiceImpl())
					//绑定地址
					.setBindAddress("localhost")
					//设置处理器个数
					.setNumHandlers(2)
					//设置端口号
					.setPort(8888).build();
			//build完之后,启动服务器
			server.start();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

创建MyClient客户端

import java.net.InetSocketAddress;

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

/**
 * 客户端
 */
public class MyClient {
	public static void main(String[] args) {
		try {
			Configuration conf = new Configuration();
			HelloWorldService proxy = RPC.getProxy(HelloWorldService.class, HelloWorldService.versionID, new InetSocketAddress("localhost",8888), conf);
			String result = proxy.sayHello("world");
			System.out.println(result);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

运行
1.启动服务器端
2.启动客户端
运行结果
启动服务端
这里写图片描述
启动客户端
这里写图片描述
启动客户端之后,服务端的反馈
这里写图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值