1.RPC简介

Remote Procedure Call 远程过程调用协议

  RPC——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。

  RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息的到达为止。当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息,获得进程结果,然后调用执行继续进行。

  hadoop的整个体系结构就是构建在RPC之上的(见org.apache.hadoop.ipc)

RPC类似于webservice,将服务发布为一个service。RPC与hadoop没有关系,如果需要我们可以在普通的项目中使用RPC机制,RPC存在commons包中。

2.首先了解Socket通信过程:(以webservice为例)

3.RPC机制(以登录为例介绍)

用到的技术:动态代理+反射+socket通信

4.RPC的例子,按照上面的思路实现登录

登录的Service部署在linux虚拟机中,以服务的形式发布(RPC发布),登录的Controller在windows中生成代理对象然后进行登录。

1.Linux中利用RPC机制发布server(发布service作为server)

LoginService .java  (需要定义一个Long型的版本号)

package cn.qlq.rpc;

import java.sql.SQLException;

public interface LoginService {

    /**
* service's verionID
*/
public static final long versionID=1L;
/**
* login method
* @param username
* @param password
* @return
* @throws SQLException
*/
public abstract String login(String username,String password)throws SQLException;
}

LoginServiceImpl .java 实现类

package cn.qlq.rpc;

import java.sql.SQLException;

public class LoginServiceImpl implements LoginService {

    @Override
public String login(String username, String password) throws SQLException {
// TODO Auto-generated method stub
return username+" logged successfully ";
} }

发布一个service作为server的类。

  1.创建builder

  2.绑定地址,端口,需要发布的类的接口,类的实例对象

  3.用builder.build()获取server

  4.用server.start()发布server

package cn.qlq.rpc;

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.Builder;
import org.apache.hadoop.ipc.Server; /**
* publish loginService
*
* @author root
*
*/
public class Publisher { public static void main(String[] a) throws HadoopIllegalArgumentException, IOException {
Builder builder = new RPC.Builder(new Configuration());
builder.setBindAddress("192.168.2.130").setPort(888).setProtocol(LoginService.class)
.setInstance(new LoginServiceImpl()); // create server and publish service
Server server = builder.build();
server.start(); } }

2.Windows利用RPC机制生成代理对象然后访问上面发布的server

1.需要将接口复制到windows中;(注意,这里的LoginService 接口所在包必须与linux中一样,否则会报协议异常)

package cn.qlq.rpc;

import java.sql.SQLException;

/**
* 登录的Service接口
* @author liqiang
*
*/
public interface LoginService { /**
* service's verionID
*/
public static final long versionID=1L;
/**
* login method
* @param username
* @param password
* @return
* @throws SQLException
*/
public abstract String login(String username,String password)throws SQLException;
}

2.生成代理对象,访问server进行登录:

package cn.qlq.rpc;

import java.io.IOException;
import java.net.InetSocketAddress;
import java.sql.SQLException; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.ipc.RPC; /**
* 登录的controller,调用hadoop的RPC生成代理对象然后访问server
*
* @author liqiang
*
*/
public class LoginController { public static void main(String[] args) throws IOException, SQLException {
//1.生成代理对象
LoginService proxy = RPC.getProxy(LoginService.class, 1L, new InetSocketAddress("192.168.2.130", 10000),new Configuration());
//2.访问server
String result = proxy.login("meinv", "111111");
System.out.println(result);
} }

结果:

meinv logged successfully 

注意:发布server的接扣的包必须与调用的接口所在包一样,否则会报未知协议异常。

总结:

  RPC机制就像webservice一样,使得程序可以运行在不同的主机上,通过socket调用,RPC更简单。发布服务与调用服务都被封装为方法。

  这样做的好处就是当我们修改了实现登录方法的代码之后不需要重新部署客户端代码,实现和接口分离。

  我们也可以在普通的web项目中利用此机制,发布server实现功能共享。

Hadoop的RPC机制及简单实现的更多相关文章

  1. hadoop的RPC机制 -源码分析

    这些天一直奔波于长沙和武汉之间,忙着腾讯的笔试.面试,以至于对hadoop RPC(Remote Procedure Call Protocol ,远程过程调用协议,它是一种通过网络从远程计算机程序上 ...

  2. Hadoop的RPC机制源码分析

    分析对象: hadoop版本:hadoop 0.20.203.0 必备技术点: 1. 动态代理(参考 :http://www.cnblogs.com/sh425/p/6893662.html )2. ...

  3. 源码级强力分析hadoop的RPC机制

    分析对象: hadoop版本:hadoop 0.20.203.0 必备技术点: 1. 动态代理(参考 :http://weixiaolu.iteye.com/blog/1477774 )2. Java ...

  4. 【Hadoop】HDFS笔记(一):Hadoop的RPC机制

    RPC(Remote Procedure Call, 远程过程调用)主要面对两个问题: 1.对象调用方式: 2.序列/反序列化机制. Hadoop实现的RPC组件依赖于Hadoop Writable类 ...

  5. Hadoop学习笔记—3.Hadoop RPC机制的使用

    一.RPC基础概念 1.1 RPC的基础概念 RPC,即Remote Procdure Call,中文名:远程过程调用: (1)它允许一台计算机程序远程调用另外一台计算机的子程序,而不用去关心底层的网 ...

  6. Hadoop RPC机制的使用

    一.RPC基础概念 1.1 RPC的基础概念 RPC,即Remote Procdure Call,中文名:远程过程调用: (1)它允许一台计算机程序远程调用另外一台计算机的子程序,而不用去关心底层的网 ...

  7. 每天收获一点点------Hadoop RPC机制的使用

    一.RPC基础概念 1.1 RPC的基础概念 RPC,即Remote Procdure Call,中文名:远程过程调用: (1)它允许一台计算机程序远程调用另外一台计算机的子程序,而不用去关心底层的网 ...

  8. Hadoop中的RPC机制

    1.  RPC——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据.在OSI ...

  9. Hadoop RPC机制详解

    网络通信模块是分布式系统中最底层的模块,他直接支撑了上层分布式环境下复杂的进程间通信逻辑,是所有分布式系统的基础.远程过程调用(RPC)是一种常用的分布式网络通信协议,他允许运行于一台计算机的程序调用 ...

随机推荐

  1. BZOJ5252 八省联考2018林克卡特树(动态规划+wqs二分)

    假设已经linkcut完了树,答案显然是树的直径.那么考虑这条直径在原树中是怎样的.容易想到其是由原树中恰好k+1条点不相交的链(包括单个点)拼接而成的.因为这样的链显然可以通过linkcut拼接起来 ...

  2. BZOJ2001 HNOI2010城市建设(线段树分治+LCT)

    一个很显然的思路是把边按时间段拆开线段树分治一下,用lct维护MST.理论上复杂度是O((M+Q)logNlogQ),实际常数爆炸T成狗.正解写不动了. #include<iostream> ...

  3. 斜率DP个人理解

    斜率DP 斜率DP的一版模式:给你一个序列,至多或分成m段,每段有花费和限制,问符合情况的最小花费是多少: 一版都用到sum[],所以符合单调,然后就可以用斜率优化了,很模板的东西: 如果看不懂可以先 ...

  4. Python从入门到放弃系列(Django/Flask/爬虫)

    第一篇 Django从入门到放弃 第二篇 Flask 第二篇 爬虫

  5. 【刷题】BZOJ 1098 [POI2007]办公楼biu

    Description FGD开办了一家电话公司.他雇用了N个职员,给了每个职员一部手机.每个职员的手机里都存储有一些同事的 电话号码.由于FGD的公司规模不断扩大,旧的办公楼已经显得十分狭窄,FGD ...

  6. 【转】安全加密(二):BLE安全攻击反制措施

    本文导读 近年来出现了越来越多的低功耗蓝牙应用,即BLE(Bluetooth Low Energy),比如说智能手环.防丢器等,对蓝牙的安全要求也越来越高.这篇文章将深入浅出说明BLE4.0~4.2中 ...

  7. B2C商城关键技术点总结(站内搜索、定时任务)

    1.站内搜索 1.1Lucene.Net建立信息索引 string indexPath = @"E:\xxx\xxx";//索引保存路径 FSDirectory directory ...

  8. HDU 1024 Max Sum Plus Plus (动态规划)

    HDU 1024 Max Sum Plus Plus (动态规划) Description Now I think you have got an AC in Ignatius.L's "M ...

  9. python(五)——运算符

    1.成员运算符,判断某个东西是否在某个东西里包含:in,not in name = "abcd" if "ac" in name: print("ok ...

  10. 解决React首屏加载白屏的问题

    众所周知,在项目中如果在资源加载请求还未完成的时候,由于阻塞机制,会出现首页白屏的问题,产生很差的用户体验.本文以react为例,提供一个解决方法. 解决原理:使用 onreadystatechang ...