一、Java的动态代理对象

实现代码如下:

  1.接口类MyService

package hdfs.proxy;

public interface MyService {

    public void method1();

    public void method2();
}

  2.接口实现类MyServiceImpl

package hdfs.proxy;

public class MyServiceImpl implements MyService {

    @Override
public void method1() {
System.out.println("************ method1 ***************");
} @Override
public void method2() {
System.out.println("************ method2 ***************"); } }

  3.测试类TestMain

package hdfs.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy; public class TestMain { public static void main(String[] args) {
//创建真正的对象
MyService obj = new MyServiceImpl(); //obj.method1(); ---> 都是直接调用真正对象
//obj.method2(); ---> 都是直接调用真正对象 /*
* Object Proxy.newProxyInstance(ClassLoader loader, 类加载器,代理对象跟真正对象是同一个类加载器
Class<?>[] interfaces, 真正对象实现的接口
InvocationHandler h) 如何处理客户端的调用
返回一个代理对象 */
//生成obj的代理对象,并且重新method2的逻辑
MyService proxy = (MyService) Proxy.newProxyInstance(TestMain.class.getClassLoader(),
obj.getClass().getInterfaces(),
new InvocationHandler() { @Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// 如何处理客户端的调用
if(method.getName().equals("method2")){
//客户端调用了method2
System.out.println("in proxy method2");
return null;
}else{
//其他方法不感兴趣
return method.invoke(obj, args);
}
}
}); //通过代理对象进行调用
proxy.method1();
proxy.method2(); } }

console:

二、RPC:远程过程调用

1.服务端:发布一个接口(MyBusiness)到RPC Server上

    实现类:MyBusinessImpl

    如果要把程序发布到Hadoop的RPC Server上,必须实现一个接口VersionedProtocol

2.客户端:调用服务器端的功能

    得到一个签名必须与服务器发布的签名的一样

得到服务器端的对象(代理对象)

实现代码如下: 

 3.MyBusiness

package demo.proxy.rpc.server;

import org.apache.hadoop.ipc.VersionedProtocol;

public interface MyBusiness extends VersionedProtocol{
//指定一个版本号,使用这个版本号来创建签名
public static long versionID = 1l; //定义自己的业务方法
public String sayHello(String name);
}

  4.MyBusinessImpl

package demo.proxy.rpc.server;

import java.io.IOException;

import org.apache.hadoop.ipc.ProtocolSignature;

public class MyBusinessImpl implements MyBusiness{

    @Override
public ProtocolSignature getProtocolSignature(String arg0, long arg1, int arg2) throws IOException {
//使用versionID创建签名
return new ProtocolSignature(versionID, null);
} @Override
public long getProtocolVersion(String arg0, long arg1) throws IOException {
// 返回ID
return versionID;
} @Override
public String sayHello(String name) {
System.out.println("*****调用Server端的方法******");
//业务方法
return "Hello" + name;
} }

  5.MyRPCServer

package demo.proxy.rpc.server;

import java.io.IOException;

import org.apache.hadoop.HadoopIllegalArgumentException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.ipc.RPC;
import org.apache.hadoop.ipc.RPC.Server; public class MyRPCServer {
public static void main(String[] args) throws HadoopIllegalArgumentException, IOException {
//ʹ创建一个RPC Server
RPC.Builder builder = new RPC.Builder(new Configuration());
//指定Server的地址接口
builder.setBindAddress("localhost");
builder.setPort(7788); //发布程序
builder.setProtocol(MyBusiness.class);//定义的接口
builder.setInstance(new MyBusinessImpl());//发布的接口的实现 //创建RPC Server
Server server = builder.build();
server.start();
}
}

6.MyRPCClient

package demo.proxy.rpc.client;

import java.net.InetSocketAddress;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.ipc.RPC; import demo.proxy.rpc.server.MyBusiness; public class MyRPCClient { public static void main(String[] args) throws Exception {
//调用Server的功能
MyBusiness proxy = RPC.getProxy(MyBusiness.class,//调用的接口
MyBusiness.versionID,//版本的ID,必须跟服务器一致
new InetSocketAddress("localhost", 7788), //服务器的地址ַ
new Configuration()); //调用服务器端的方法
System.out.println(proxy.sayHello("梦里南柯")); } }

先启动Server端,再启动Client端

大数据笔记(六)——HDFS的底层原理:JAVA动态代理和RPC的更多相关文章

  1. AOP的底层实现-CGLIB动态代理和JDK动态代理

    AOP是目前Spring框架中的核心之一,在应用中具有非常重要的作用,也是Spring其他组件的基础.它是一种面向切面编程的思想.关于AOP的基础知识,相信多数童鞋都已经了如指掌,我们就略过这部分,来 ...

  2. 大数据 --> 分布式文件系统HDFS的工作原理

    分布式文件系统HDFS的工作原理 Hadoop分布式文件系统(HDFS)是一种被设计成适合运行在通用硬件上的分布式文件系统.HDFS是一个高度容错性的系统,适合部署在廉价的机器上.它能提供高吞吐量的数 ...

  3. 最近整理出了有关大数据,微服务,分布式,Java,Python,Web前端,产品运营,交互等1.7G的学习资料,有视频教程,源码,课件,工具,面试题等等。这里将珍藏多年的资源免费分享给各位小伙伴们

    大数据,微服务,分布式,Java,Python,Web前端,产品运营,交互 领取方式在篇尾!!! 基础篇.互联网架构,高级程序员必备视频,Linux系统.JVM.大型分布式电商项目实战视频...... ...

  4. jdk动态代理和cglib动态代理底层实现原理详细解析(cglib动态代理篇)

    代理模式是一种很常见的模式,本文主要分析cglib动态代理的过程 1. 举例 使用cglib代理需要引入两个包,maven的话包引入如下 <!-- https://mvnrepository.c ...

  5. 大数据笔记(四)——操作HDFS

    一.Web Console:端口50070 二.HDFS的命令行操作 (一)普通操作命令 HDFS 操作命令帮助信息: hdfs dfs + Enter键 常见命令 1.  -mkdir 在HDFS上 ...

  6. 大数据入门第六天——HDFS详解

    一.概述 1.HDFS中的角色 Block数据: HDFS中的文件在物理上是分块存储(block),块的大小可以通过配置参数( dfs.blocksize)来规定,默认大小在hadoop2.x版本中是 ...

  7. 大数据小白系列——HDFS(2)

    这里是大数据小白系列,这是本系列的第二篇,介绍一下HDFS中SecondaryNameNode.单点失败(SPOF).以及高可用(HA)等概念. 上一篇我们说到了大数据.分布式存储,以及HDFS中的一 ...

  8. 大数据小白系列——HDFS(1)

    [注1:结尾有大福利!] [注2:想写一个大数据小白系列,介绍大数据生态系统中的主要成员,理解其原理,明白其用途,万一有用呢,对不对.] 大数据是什么?抛开那些高大上但笼统的说法,其实大数据说的是两件 ...

  9. 大数据开发实战:MapReduce内部原理实践

    下面结合具体的例子详述MapReduce的工作原理和过程. 以统计一个大文件中各个单词的出现次数为例来讲述,假设本文用到输入文件有以下两个: 文件1: big data offline data on ...

随机推荐

  1. Linux cat 多行写入文件防止变量替换

    Linux cat 多行写入文件防止变量替换  问题描述 对多个变量及多行输出到文件,存在变量自动替换,当使用cat<<EOF不想对内容进行变量替换.命令替换.参数展开等 问题解决 转义特 ...

  2. Windows上Tomcat安装以及解决乱码问题

    Windows上Tomcat安装以及解决乱码问题 下载tomcat8 1.进入tomcat官网 官方网站 2.选择windows的版本 解压 确定自己配置好了jdk jdk的相关配置 配置好tomca ...

  3. MyBatis一个对多个主键(索引)生成实体类的处理

    原数据库表: 生成实体类,多出了一个xxKey.java

  4. mac下安装php zookeeper扩展

    安装步骤 php-zookeeper依赖libzookeeper,所以需要先安装libzookeeper 安装libzookeeper cd /usr/local/src/ wget http://m ...

  5. 小白学Python——Matplotlib 学习(2):pyplot 画图

    matplotlib.pyplot是一组命令样式函数,使matplotlib像MATLAB一样工作.每个pyplot函数都会对图形进行一些更改:例如,创建图形,在图形中创建绘图区域,在绘图区域中绘制一 ...

  6. Socket通讯-C#客户端与Java服务端通讯(发送消息和文件)

    设计思路 使用websocket通信,客户端采用C#开发界面,服务端使用Java开发,最终实现Java服务端向C#客户端发送消息和文件,C#客户端实现语音广播的功能. Java服务端设计 packag ...

  7. 关于BeanUtils.copyProperties的用法和优缺点

    一.简介:  BeanUtils提供对Java反射和自省API的包装.其主要目的是利用反射机制对JavaBean的属性进行处理.我们知道,一个JavaBean通常包含了大量的属性,很多情况下,对Jav ...

  8. ntsysv - 用于配置运行级别的简单接口

    总览 SYNOPSIS ntsysv [--back] [--level <levels>] 描述 DESCRIPTION ntsysv 是个用于配置运行级别服务(也可通过 chkconf ...

  9. POJ 3667 Hotel (线段树区间合并)

    题目链接:http://poj.org/problem?id=3667 题目大意:一共有n个房间,初始时都是空的,现在有m个操作,操作有以下两种: 1.1 d :询问是否有连续d个空的房间,若有则输出 ...

  10. CCPC-Wannafly Winter Camp Day1 (Div2, onsite) 夺宝奇兵

    题目描述 wlswls所在的王国有nn个居民(不包括wlswls),他们共有mm件神奇的宝物. 对于第ii件宝物,wlswls可以花费a_iai​的金币把它从原来的主人那里买过来. 请问wlswls最 ...