`

thrift实现java与ruby的交互

    博客分类:
  • java
阅读更多
thrift在apache中主页http://thrift.apache.org/

Thrift是一个可以提供跨语言开发的框架,它允许你在一个配置文件中定义数据类型和服务接口 ,把这个文件作为输入,编译器产生的代码将要被用来建立RPC客户端和服务端的跨语言的无缝连接。
thrift0.5的下载地址
http://www.apache.org/dyn/closer.cgi?path=/incubator/thrift/0.5.0-incubating/thrift-0.5.0.tar.gz
下载之后编译安装

开始交互之旅
thrift的数据类型:

1 基本数据类型有
bool: A boolean value (true or false)
byte: An 8-bit signed integer
i16: A 16-bit signed integer
i32: A 32-bit signed integer
i64: A 64-bit signed integer
double: A 64-bit floating point number
string: A text string encoded using UTF-8 encoding

2 特殊类型
binary: a sequence of unencoded bytes

3 结构体
4 容器
list<type>: An ordered list of elements. Translates to an STL vector, Java ArrayList, native arrays in scripting languages, etc.
set<type>: An unordered set of unique elements. Translates to an STL set, Java HashSet, set in Python, etc. This type is not supported in PHP! Use lists instead.
map<type1,type2>: A map of strictly unique keys to values. Translates to an STL map, Java HashMap, PHP associative array, Python/Ruby dictionary, etc.



一、新建thrift文件 user.thrift
struct User {
  1: string id,
  2: string name,
}

service UserStorage {
  void set_user(1: User user),
  User get_user(1: string id)
}


在此目录下运行thrift命令,生成相应的java文件和ruby文件
生成java相关文件的命令:
thrift -r -gen java user.thrift

生成ruby相关文件的命令:
thrift -r -gen rb user.thrift


执行命令之后,会发现此目录下面产生了两个文件夹gen-java 和 gen-rb
gen-java下面有两个文件 User.java(对struct User的实现) 和 UserStorage.java(对service UserStorage的实现)
gen-rb 下面有三个文件 user_storage.rb(对service UserStorage的实现) , user_types.rb ,user_constants.rb(后面两个文件对struct User的实现,后者只有一句话require 'user_types')

二、用java做服务端
新建一个java工程,将两个java文件引入,下面开始实现服务
首先要实现那两个自定一个接口方法
public class UserServiceHandler  implements UserStorage.Iface {

  public void set_user(User user) throws TException {
    System.out.println(user.name + " " + user.id);
  }

  public User get_user(String id) throws TException {
    // 没有逻辑意义,纯粹是为了返回一个user
    User user = new User();
    user.setId(id);
    user.setName("user_one");
    return user;
  }
  
}


启动java这边的服务
  public static void main(String[] args) {
    try {
      UserServiceHandler handler = new UserServiceHandler();
      UserStorage.Processor processor = new UserStorage.Processor(handler);
      TServerTransport serverTransport = new TServerSocket(9090);
      TServer server = new TSimpleServer(processor, serverTransport);
      // Use this for a multithreaded server
      // server = new TThreadPoolServer(processor, serverTransport);
      System.out.println("Starting the server...");
      server.serve();
    } catch (TTransportException tTransportException) {
    }
  }


三 ruby客户端

require 'thrift'
require 'user_constants'
require 'user_storage'

transport = Thrift::BufferedTransport.new(Thrift::Socket.new('localhost', 5555))
protocol = Thrift::BinaryProtocol.new(transport)
client = UserStorage::Client.new(protocol)

transport.open()

user = client.get_user('123')
p user



运行ruby的客户端,即可输出接口所设置的user
属性如下
id 123
name user_one




分享到:
评论
2 楼 hotsunshine 2014-09-02  
vikki 写道
沙发先。

楼主,这些代码例子你都运行过吗?

运行过,但是这已经是好几年的事情了,跟你现在的环境未必能匹配的上,估计api也变了不少,你可以参考一下
1 楼 vikki 2014-08-22  
沙发先。

楼主,这些代码例子你都运行过吗?

相关推荐

    thrift介绍、各种server的比较、多接口服务实现

    2. 多语言支持:Thrift 支持多种编程语言,如 C++, Java, Python, PHP, Ruby 等,允许不同语言间的服务交互。 3. 命名空间:每个 Thrift 文件有自己的命名空间,避免了标识符冲突。 4. 基础类型:包括 bool, byte, i...

    Thrift框架使用分享

    Thrift框架通过接口描述语言(IDL)来定义服务,支持多种编程语言,如C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk等,并能生成相应语言的服务端和客户端代码。其传输数据采用二进制...

    thrift介绍与实践

    1. **跨语言**:Thrift支持多种编程语言,如C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa等,使得开发者可以自由选择后端服务的语言,同时提供前端客户端的多种实现。 2. **高性能**:Thrift...

    thrift的使用介绍

    它支持多种编程语言,包括C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Node.js, Smalltalk等,使服务跨语言交互变得容易。 **6. 性能优化** Thrift提供了多种传输和协议选项,可以根据实际需求选择...

    thrift-0.5.0.tar.gz linux版本

    5. **语言绑定**:预生成的客户端和服务器端代码模板,支持如Python、Java、C#、PHP、Ruby等多语言。 6. **文档**:包括README和API文档,帮助开发者理解和使用Thrift。 Thrift的使用流程大致如下: 1. **定义服务*...

    Thrift工具和依赖的jar包

    4. **多语言支持**:Thrift支持包括Java、Python、C++、PHP、Ruby、C#、Go等在内的多种编程语言,极大地提高了代码的可重用性和互操作性。 5. **服务器和客户端库**:编译后的Thrift代码包含服务器端的处理程序接口...

    thrift基础文档

    6. **客户端库**:同样自动生成的客户端库提供了与服务端交互的API。 学习Thrift,你需要理解以下关键概念: - **服务(Service)**:定义了远程方法调用的接口,包括方法名、参数和返回值。 - **数据结构...

    thrift源码+DEMO+简单教程

    Thrift IDL是Thrift的核心部分,它是一种类似C++或Java的语法,用于定义服务接口和数据结构。通过IDL,开发者可以声明服务方法、数据类型(如结构体、枚举、常量)以及服务间的交互方式。例如: ```idl service ...

    thrift-0.9.2.tar.gz

    3. **库文件**:压缩包中包含了各种目标语言的库文件,这些库提供了与 Thrift 服务交互的 API,包括数据类型、协议处理和传输层的实现。 4. **示例和测试**:Thrift 的源码通常会包含一些示例项目和测试用例,帮助...

    P4中thrift-0.9.2和nanomsg-1.0.0.zip

    在P4环境中,Thrift可以用于实现P4控制平面与数据平面之间的通信,例如,bmv2(Behavioral Model v2)的JSON接口就利用了Thrift进行编译器与硬件模拟器之间的交互。 thrift-0.9.2.tar.gz文件包含了Thrift的源代码和...

    thrift-0.9.3

    在“thrift-0.9.3”这个特定的版本中,我们拥有的是代码生成引擎,它能够自动生成各种编程语言的客户端和服务器端代码,使得开发人员可以快速地实现跨平台的服务交互。 Thrift 的工作流程分为以下几个关键步骤: 1...

    thrift-0.10.0

    4. 兼容性增强:Thrift 0.10.0 可能提升了与其他软件或库的兼容性,比如更新的协议规范,使得与其他系统的集成更加平滑。 5. 文档改进:新版本通常会伴随着文档的更新和改进,提供更详尽的使用指南和示例,帮助...

    基于Thrift框架的数据交换方案_梁明炯.pdf

    1. **跨语言支持**:Thrift支持C++、Java、Python、PHP、Ruby、Perl、C#、Cocoa、JavaScript等多种编程语言,使得开发者可以在不同语言之间轻松构建服务。 2. **代码生成引擎**:Thrift通过定义一套接口描述语言...

    ThriftC#实现

    Thrift 的核心优势在于其能够支持多种现代编程语言,包括但不限于 C++、C#、Java、Python、PHP 和 Ruby,并通过代码生成机制简化了这些语言之间的互操作性。 Thrift 的工作流程主要分为两个阶段:定义和服务交互。...

    thrift-rpc-client

    Thrift通过定义一种中间表示(IDL,Interface Description Language)来描述服务接口,然后自动生成不同语言的客户端和服务器端代码,支持包括Java、Python、C++、PHP、Ruby等多种编程语言。 在Java环境中,Thrift-...

    bijection-thrift_2.9.3-0.5.2.zip

    标题 "bijection-thrift_2.9.3-0.5.2.zip" 提供了有关此压缩包的初步信息,表明它包含了与 Bijection 和 Thrift 相关的组件,版本号为 2.9.3 和 0.5.2。Bijection 是一个由 Twitter 开发的 Scala 库,用于在 Scala ...

    hbase用于查询客户端工具

    HBase的Thrift接口为非Java应用提供了一种与HBase交互的方式。通过Thrift,开发者可以在Python、PHP、C++等语言中方便地操作HBase。 4. **Phoenix**:Phoenix是Apache的一个开源项目,它提供了一个SQL层,用于在...

    MaxCompute大数据生态集成和开发工具.pdf

    为了满足不同用户的需求,MaxCompute 2.0实现了对Hive Thrift协议的兼容,这意味着可以使用Beeline、Hive ODBC和Tableau等工具直接与MaxCompute进行交互。此外,MaxCompute还支持R和Python Pandas这两种广泛使用的...

    hbase源码带中文注释

    通过Thrift,你可以用Python、C++、Ruby等语言与HBase通信。研究源码有助于掌握服务端和客户端之间的通信协议。 5. **HBase Client**: 包含了客户端API,提供了与HBase交互的各种方法,如创建表、删除表、插入数据...

    heegproto

    综上,"heegproto"项目是一个涉及到Thrift协议的实际应用案例,通过学习和理解Thrift,开发者可以更好地理解和使用该项目,实现高效的数据通信和服务交互。在实际开发中,还需要结合具体的业务需求和系统环境,灵活...

Global site tag (gtag.js) - Google Analytics