Thrift交流(一)简单的Thrift

转载自 CSDN Arjick


Thrift是一个可伸缩的跨语言的服务开发框架,是facebook开发的一个跨语言通信平台。为各种语言提供快捷的rpc服务。现阶段已经支持C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk, and OCaml等语言。在近来的工作中,重新学习Thrift通信的内容,和大家做个简单的交流。

Thrift示意图



1)安装Thrift环境

Thrift的环境的安装并不复杂,我们现在以最简单的windows环境做个案例。

首先在官方网站下载最新的thrift exe文件,http://thrift.apache.org/download/

然后把exe文件改名为thrift.exe,放在了windows的目录下,如图所示:


接着配置thrift环境变量:

测试Thrift运行环境:


2)编写Thrift文件

thrift文件如下

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. namespace java thrift  // defines the namespace    
  2.      
  3. typedef i32 int  //typedefs to get convenient names for your types  
  4.   
  5. service ThriftService {    
  6.     int add(1:int a,2:int b),  
  7. }  

通过命令行执行Thrift文件,并生成


3)建立Thrift工程

首先建立maven工程,把如下内容加到pom.xml

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <dependency>  
  2.             <groupId>org.apache.thrift</groupId>  
  3.             <artifactId>libthrift</artifactId>  
  4.             <version>0.9.0</version>  
  5.         </dependency>  
  6.         <dependency>  
  7.             <groupId>org.slf4j</groupId>  
  8.             <artifactId>slf4j-api</artifactId>  
  9.             <version>1.7.5</version>  
  10.         </dependency>  
  11.         <dependency>  
  12.             <groupId>org.slf4j</groupId>  
  13.             <artifactId>slf4j-simple</artifactId>  
  14.             <version>1.7.5</version>  
  15.         </dependency>  
  16.   
  17.         <dependency>  
  18.             <groupId>org.slf4j</groupId>  
  19.             <artifactId>slf4j-log4j12</artifactId>  
  20.             <version>1.7.5</version>  
  21.         </dependency>  
  22.         <dependency>  
  23.             <groupId>log4j</groupId>  
  24.             <artifactId>log4j</artifactId>  
  25.             <version>1.2.17</version>  
  26.         </dependency>  


[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1.   
编写ThriftService的实现类:

代码如下:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package thrift;  
  2.   
  3. import org.apache.thrift.TException;  
  4.   
  5. public class ThriftServiceImpl implements Iface {  
  6.   
  7.     @Override  
  8.     public int add(int a, int b) throws TException {  
  9.         return a + b;  
  10.     }  
  11.   
  12. }  

4)编写服务器及测试

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.duowan.yy.thriftTest;  
  2.   
  3. import org.apache.thrift.TProcessor;  
  4. import org.apache.thrift.protocol.TBinaryProtocol;  
  5. import org.apache.thrift.protocol.TBinaryProtocol.Factory;  
  6. import org.apache.thrift.server.TServer;  
  7. import org.apache.thrift.server.TSimpleServer;  
  8. import org.apache.thrift.transport.TServerSocket;  
  9. import org.apache.thrift.transport.TTransportException;  
  10.   
  11. import thrift.ThriftService;  
  12. import thrift.ThriftServiceImpl;  
  13.   
  14. public class ThriftServer {  
  15.     public static void main(String[] args) {  
  16.         try {  
  17.             TServerSocket serverTransport = new TServerSocket(7911);  
  18.   
  19.             Factory proFactory = new TBinaryProtocol.Factory();  
  20.   
  21.             TProcessor processor = new ThriftService.Processor<ThriftService.Iface>(  
  22.                     new ThriftServiceImpl());  
  23.             TServer.Args tArgs = new TServer.Args(serverTransport);  
  24.             tArgs.processor(processor);  
  25.             tArgs.protocolFactory(proFactory);  
  26.   
  27.             TServer server = new TSimpleServer(tArgs);  
  28.             System.out.println("Start server on port 7911....");  
  29.             server.serve();  
  30.         } catch (TTransportException e) {  
  31.             e.printStackTrace();  
  32.         }  
  33.     }  
  34. }  

测试启动:



编写测试类:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.duowan.yy.thriftTest;  
  2.   
  3. import org.apache.thrift.TException;  
  4. import org.apache.thrift.protocol.TBinaryProtocol;  
  5. import org.apache.thrift.protocol.TProtocol;  
  6. import org.apache.thrift.transport.TSocket;  
  7. import org.apache.thrift.transport.TTransport;  
  8. import org.apache.thrift.transport.TTransportException;  
  9.   
  10. import thrift.ThriftService;  
  11.   
  12.   
  13. public class Test {  
  14.   
  15.     /** 
  16.      * @param args 
  17.      */  
  18.     public static void main(String[] args) {  
  19.         try {  
  20.             TTransport transport = new TSocket("localhost"7911);  
  21.             transport.open();  
  22.             TProtocol protocol = new TBinaryProtocol(transport);  
  23.             ThriftService.Client client = new ThriftService.Client(protocol);  
  24.             System.out.println(client.add(775));  
  25.             transport.close();  
  26.   
  27.         } catch (TTransportException e) {  
  28.             // TODO Auto-generated catch block  
  29.             e.printStackTrace();  
  30.         } catch (TException e) {  
  31.             // TODO Auto-generated catch block  
  32.             e.printStackTrace();  
  33.         }  
  34.     }  
  35.   
  36. }  

  效果如下:



简单的Thrift之旅已经完成了,希望大家玩的开心。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值