日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

四步完成跨平臺調(diào)用——thrift的開發(fā)應(yīng)用 - Bir

系統(tǒng) 2415 0

四步完成跨平臺調(diào)用——thrift的開發(fā)應(yīng)用 - Birdshover - 博客園

四步完成跨平臺調(diào)用——thrift的開發(fā)應(yīng)用

一、安裝thrift

首先,你要有個Linux平臺,反正安裝好了就行,用不著太多的東西。

?

thrift這個東東可以在http://www.thrift-rpc.org/下載。

具體在http://www.thrift-rpc.org/?p=thrift.git;a=shortlog;h=refs/misc/instant,一般點第一個snapshot就行了,這是最新的。版本幾個小時更新一個,太牛叉了。

接下來,安裝thrift。到thrift的解壓目錄,執(zhí)行命令:

#chmod +x *? //設(shè)置執(zhí)行權(quán)限

#./bootstrap.sh

#./configure

#make

#make install

二、確定接口

平臺與平臺的方法調(diào)用或數(shù)據(jù)交換,需要依賴一組結(jié)構(gòu)和一些方法。需要定義好這個方法,才可以進行接下來的開發(fā)。比如,我現(xiàn)在需要通過C#調(diào)用Java。如果說Java的服務(wù)端已經(jīng)開發(fā)好了,那就非常像是適配器模式了。

現(xiàn)在書寫一個簡單的接口:

service ThriftTest
{
?void work();
?i32 test(1:string s);
}

service ThriftTest

{

????????? void work();

????????? i32 test(1:string s);

}

(注:復(fù)雜一些的接口可以參考下載來包里的thrift\test目錄下的*.thrift文件。)

現(xiàn)在開始生成代碼:

# /home/xieping/thrift/compiler/cpp/thrift -gen java test.thrift

# /home/xieping/thrift/compiler/cpp/thrift -gen csharp test.thrift

分別生成了java和csharp的應(yīng)用,在gen-java和gen-csharp目錄下。

三、開發(fā)服務(wù)端

把Java下的ThriftTest類拷貝到項目中,注意添加package。定義服務(wù)類ThriftServer,實現(xiàn)ThriftTest.Iface接口。(項目需要引用thrift\lib\java\src里的項目。同時需要引用slf4j-log4j12-1.5.11.jar,slf4j-api-1.5.11.jar,log4j-1.3alpha-8.jar三個包。)

import org.apache.thrift.TException;

public class ThriftServer implements ThriftTest.Iface {

@Override

public int test(String s) throws TException {

// TODO Auto-generated method stub

return Integer.parseInt(s);

}

@Override

public void work() throws TException {

// TODO Auto-generated method stub

System.out.println("ccc");

}

}

在main方法中寫入:

try {

ThriftServer t = new ThriftServer();

ThriftTest.Processor p = new ThriftTest.Processor(t);

???? TServerTransport serverTransport = new TServerSocket(9090);

???? TServer server = new TThreadPoolServer(p, serverTransport);

???? // Use this for a multithreaded server

???? // server = new TThreadPoolServer(processor, serverTransport);

???? System.out.println("Starting the server...");

???? server.serve();

?? } catch (Exception x) {

???? x.printStackTrace();

?? }

?? System.out.println("done.");

這里的Server有好幾種,我使用了TThreadPoolServer.運行,服務(wù)端就OK了。

四、客戶端調(diào)用

客戶端把gen-csharp里的類,拷貝到項目中。引用thrift\lib\csharp\src里的項目。

然后編寫代碼:

static void Main(string[] args) {

TTransport transport = new TSocket("localhost",9090);

TProtocol protocol = new TBinaryProtocol(transport);

ThriftTest.Client client = new ThriftTest.Client(protocol);

transport.Open();

int val = client.test("1213");

client.work();

transport.Close();

Console.WriteLine(val);

}

運行,出結(jié)果了。

四步就完成了通過Thrift跨平臺調(diào)用的目的。Java和C#還好些,php調(diào)用Java的相對來說使用上更廣泛一些。

分類: .Net language and other

四步完成跨平臺調(diào)用——thrift的開發(fā)應(yīng)用 - Birdshover - 博客園


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 博罗县| 英吉沙县| 资源县| 宝清县| 得荣县| 阜平县| 依兰县| 安国市| 平昌县| 武隆县| 德化县| 达日县| 武冈市| 彩票| 新平| 太仓市| 芒康县| 大庆市| 泰和县| 扎囊县| 蒲城县| 徐州市| 罗田县| 安多县| 施秉县| 外汇| 平谷区| 资兴市| 石首市| 姚安县| 石渠县| 广东省| 信阳市| 韶关市| 庆云县| 东阳市| 富宁县| 庐江县| 沧州市| 莒南县| 阳原县|