我是靠谱客的博主 爱笑大侠,最近开发中收集的这篇文章主要介绍考察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.启动客户端
运行结果
启动服务端
这里写图片描述
启动客户端
这里写图片描述
启动客户端之后,服务端的反馈
这里写图片描述

最后

以上就是爱笑大侠为你收集整理的考察Hadoop的底层rpc通信(一)的全部内容,希望文章能够帮你解决考察Hadoop的底层rpc通信(一)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部