基于Hadoop的RPC原理实现

简单来说就是一台机器上的应用想调用另一台机器上的函数或者方法,由于不在同一个内存空间中,所以不能直接调用,要使用RPC协议来调用

下边就来基于Hadoop来实现RPC调用

1.加入Hadoop的依赖包

<repositories>
    <repository>
      <id>cloudera</id>
      <url>http://repository.cloudera.com/a ... a-repos</url>
    </repository>
</repositories>

<dependency>
      <groupId>org.apache.hadoop</groupId>
      <artifactId>hadoop-client</artifactId>
      <version>2.5.0-cdh5.3.6</version>
</dependency>
如果是CDH版本的Hadoop,需要加入repository,如果是apache版本的则不需要

2.创建服务器端

UserServer接口:

package cn.ysjh.drpc;


public interface UserService {

    public static final long versionID=8888;

   public void addUser(String name,int age);

}
UserServerImpl实现类:

package cn.ysjh.drpc;

public class UserServerImpl implements UserService {
    @Override
    public void addUser(String name, int age) {
        System.out.println("姓名:"+name+" "+"年龄"+age);
    }
}
ServerRPC服务器端代码:

package cn.ysjh.drpc;

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

/*
    RPC服务
*/
public class ServerRPC {

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

      Configuration configuration = new Configuration();

      RPC.Builder builder = new RPC.Builder(configuration);

      RPC.Server server = builder.setProtocol(UserService.class)
              .setInstance(new UserServiceImpl())
              .setBindAddress("localhost")
              .setPort(9999)
              .build();

      server.start();

  }

}
3.实现Client端

package cn.ysjh.drpc;

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

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

/*
客户端
*/
public class UserClient {

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

      Configuration configuration = new Configuration();

      long clientVersion=8888;

      UserService proxy = RPC.getProxy(UserService.class, clientVersion, new InetSocketAddress("localhost", 9999), configuration);

      proxy.addUser("lisi",22);

      System.out.println("添加成功");



  }

}
4.运行代码

先运行服务器端代码,然后运行client端代码

只要client端有请求,server端的方法就会被调用
--------------------- 
作者:ysjh0014 
来源:CSDN 
原文:https://blog.csdn.net/ys_230014/article/details/84072734 
版权声明:本文为博主原创文章,转载请附上博文链接!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值