Hadoop的RPC通信------>java实现

一 、服务端编写

(1)RPCServer类 

public class RPCServer implements Bizable{

    public  String sayHi(String name){
        return "Hi~"+name;
    }

    public static void main(String[] args) throws Exception {
        Configuration conf = new Configuration();
        RPC.Server server = new RPC.Builder(conf)
                .setProtocol(Bizable.class)
                .setInstance(new RPCServer())
                .setBindAddress("192.168.19.10")
                .setPort(9527)
                .build();
        server.start();
    }
}

(2)Bizable接口

public interface Bizable {
    public static final long versionID=10010L;
    public String sayHi(String name);
}

二 、客户端编写

public class RPCClient {
    public static void main(String[] args) throws Exception {
        Bizable proxy = RPC.getProxy(Bizable.class, 10010L, new InetSocketAddress("192.168.19.10", 9527),
                new Configuration());
        String result = proxy.sayHi("小虹尘");
        System.out.println("==============================================================");
        System.out.println(result);
        System.out.println("==============================================================");
        RPC.stopProxy(proxy);
    }
}

三 、 测试

(1)本地客户端与服务端通信

   运行RPCServer类------>运行RPCClient类 ,运行结果如图:

  

(2)虚拟机与本机通信

  

使用idea软件打可运行的Jar包

     File------>Project Structure------>Artifacts------> + ------>Jar------>From Module And Dependences



------>Main Class------>RPCClient------>Copy to the output directory and link via manifest

              

------>Apply------>OK

  【2】将打好的文件../out/artifacts/hadoop_jar_jar上传到虚拟机下

  【3】在主机,运行本地的RPCServer类

  【4】进入到hadoop_jar_jar目录下

     cd hadoop_jar_jar

     运行jar包 java -jar 包名

     例如:java -jar hadopp_jar.jar


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值