真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

利用Hadoop提供的RPCAPI實(shí)現(xiàn)簡單的RPC程序

[toc]

創(chuàng)新互聯(lián)基于分布式IDC數(shù)據(jù)中心構(gòu)建的平臺(tái)為眾多戶提供電信內(nèi)江機(jī)房 四川大帶寬租用 成都機(jī)柜租用 成都服務(wù)器租用。


利用Hadoop提供的RPC API實(shí)現(xiàn)簡單的RPC程序

在Hadoop中提供了RPC服務(wù)的使用API,通過其API地使用,可以非常簡單地構(gòu)建遠(yuǎn)程過程調(diào)用程序,下面就給出一個(gè)簡單的實(shí)例。

項(xiàng)目結(jié)構(gòu)

為了方便操作,所有的代碼都放在本地一個(gè)項(xiàng)目中,實(shí)際上,完全可以將代碼放在不同的服務(wù)器上,這是RPC的概念,這里就不做過多的介紹。
項(xiàng)目結(jié)構(gòu)如下:

rpc/
├── HelloServiceImpl.java
├── IHelloService.java
├── RPCClientDriver.java
└── RPCServerDriver.java

程序代碼

這里只是做一個(gè)簡單的示例,并且代碼中也給出了非常詳細(xì)的注釋,所以直接給出程序代碼。

IHelloService.java
package com.uplooking.bigdata.rpc;

import org.apache.hadoop.ipc.VersionedProtocol;

/**
 * 接口
 * 要想使用hadoop提供的RPC服務(wù),必須要繼承VersionedProtocol
 */
public interface IHelloService extends VersionedProtocol {

    public long versionID = 1L;

    public String sayHi(String name);

    public String hearBeat(String beat);
}
HelloServiceImpl.java
package com.uplooking.bigdata.rpc;

import org.apache.hadoop.ipc.ProtocolSignature;

import java.io.IOException;

/**
 * HelloService服務(wù)實(shí)現(xiàn)類
 */
public class HelloServiceImpl implements IHelloService {

    public String sayHi(String name) {
        System.out.println("name..." + name);
        return "Hi, " + name;
    }

    public String hearBeat(String beat) {
        System.out.println("----heartbeat----" + beat);
        return System.currentTimeMillis() + "--->" + beat;
    }

    public long getProtocolVersion(String protocol, long clientVersion) throws IOException {
        return versionID;
    }

    public ProtocolSignature getProtocolSignature(String protocol, long clientVersion, int clientMethodsHash) throws IOException {
        return new ProtocolSignature();
    }
}
RPCServerDriver.java
package com.uplooking.bigdata.rpc;

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

import java.io.IOException;

/**
 * RPC服務(wù)端程序,啟動(dòng)并發(fā)布服務(wù)
 */
public class RPCServerDriver {

    public static void main(String[] args) throws IOException {
        // 創(chuàng)建RPC的配置
        Configuration configuration = new Configuration();
        // 構(gòu)建RPC的builder對象
        RPC.Builder builder = new RPC.Builder(configuration);
        // 設(shè)置RPC Server的信息,返回一個(gè)server對象
        RPC.Server server = builder.setBindAddress("localhost")
                .setPort(4893)
                .setProtocol(IHelloService.class)
                .setInstance(new HelloServiceImpl())
                .build();
        // 啟動(dòng)RPC Server
        // 這是一個(gè)守護(hù)進(jìn)程,所以main函數(shù)不會(huì)退出
        server.start();

        System.out.println("---服務(wù)啟動(dòng)了---");

    }

}
RPCClientDriver.java
package com.uplooking.bigdata.rpc;

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

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

/**
 * RPC客戶端程序
 */
public class RPCClientDriver {
    public static void main(String[] args) throws IOException {
        // 構(gòu)建InetSocketAddress對象
        InetSocketAddress address = new InetSocketAddress(InetAddress.getByName("localhost"), 4893);
        // 通過RPC.getProxy方法獲得代理對象
        /**
         * @param protocol      接口的類型對象
         * @param clientVersion 版本號
         * @param addr          服務(wù)端地址
         * @param conf          配置信息
         */
        IHelloService helloServiceProxy = RPC.getProxy(IHelloService.class, IHelloService.versionID, address, new Configuration());
        String result = helloServiceProxy.sayHi("小秋田");
        System.out.println(result);
    }
}

測試

啟動(dòng)RPCServerDriver,輸出如下:

---服務(wù)啟動(dòng)了---

啟動(dòng)RPCClicentDriver,輸出如下:

Hi, 小秋田

此時(shí)再查看服務(wù)端的輸出:

---服務(wù)啟動(dòng)了---
name...小秋田

這樣的話,通過使用Hadoop提供的RPC API,就實(shí)現(xiàn)了一個(gè)簡單的RPC程序。


網(wǎng)頁題目:利用Hadoop提供的RPCAPI實(shí)現(xiàn)簡單的RPC程序
當(dāng)前鏈接:http://weahome.cn/article/gcoiec.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部