四步完成跨平臺(tái)調(diào)用——thrift的開發(fā)應(yīng)用 - Birdshover - 博客園
四步完成跨平臺(tái)調(diào)用——thrift的開發(fā)應(yīng)用
一、安裝thrift
首先,你要有個(gè)Linux平臺(tái),反正安裝好了就行,用不著太多的東西。
?
thrift這個(gè)東東可以在http://www.thrift-rpc.org/下載。
具體在http://www.thrift-rpc.org/?p=thrift.git;a=shortlog;h=refs/misc/instant,一般點(diǎn)第一個(gè)snapshot就行了,這是最新的。版本幾個(gè)小時(shí)更新一個(gè),太牛叉了。
接下來,安裝thrift。到thrift的解壓目錄,執(zhí)行命令:
#chmod +x *? //設(shè)置執(zhí)行權(quán)限
#./bootstrap.sh
#./configure
#make
#make install
二、確定接口
平臺(tái)與平臺(tái)的方法調(diào)用或數(shù)據(jù)交換,需要依賴一組結(jié)構(gòu)和一些方法。需要定義好這個(gè)方法,才可以進(jìn)行接下來的開發(fā)。比如,我現(xiàn)在需要通過C#調(diào)用Java。如果說Java的服務(wù)端已經(jīng)開發(fā)好了,那就非常像是適配器模式了。
現(xiàn)在書寫一個(gè)簡(jiǎ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類拷貝到項(xiàng)目中,注意添加package。定義服務(wù)類ThriftServer,實(shí)現(xiàn)ThriftTest.Iface接口。(項(xiàng)目需要引用thrift\lib\java\src里的項(xiàng)目。同時(shí)需要引用slf4j-log4j12-1.5.11.jar,slf4j-api-1.5.11.jar,log4j-1.3alpha-8.jar三個(gè)包。)
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.運(yùn)行,服務(wù)端就OK了。
四、客戶端調(diào)用
客戶端把gen-csharp里的類,拷貝到項(xiàng)目中。引用thrift\lib\csharp\src里的項(xiàng)目。
然后編寫代碼:
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);
}
運(yùn)行,出結(jié)果了。
四步就完成了通過Thrift跨平臺(tái)調(diào)用的目的。Java和C#還好些,php調(diào)用Java的相對(duì)來說使用上更廣泛一些。
分類: .Net language and other
四步完成跨平臺(tái)調(diào)用——thrift的開發(fā)應(yīng)用 - Birdshover - 博客園
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
