thrift 交互ruby 和java

来源:互联网 发布:ce引擎知乎 编辑:程序博客网 时间:2024/05/17 16:55
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 基本数据类型有
Java代码 复制代码 收藏代码
  1. bool: A boolean value (true orfalse)
  2. byte: An 8-bit signed integer
  3. i16: A 16-bit signed integer
  4. i32: A 32-bit signed integer
  5. i64: A 64-bit signed integer
  6. double: A 64-bit floating point number
  7. string: A text string encoded using UTF-8 encoding

2 特殊类型
Java代码 复制代码 收藏代码
  1. binary: a sequence of unencoded bytes

3 结构体
4 容器
Java代码 复制代码 收藏代码
  1. list<type>: An ordered list of elements. Translates to an STL vector, Java ArrayList,native arrays in scripting languages, etc.
  2. 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.
  3. 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
Xml代码 复制代码 收藏代码
  1. struct User {
  2. 1: string id,
  3. 2: string name,
  4. }
  5. service UserStorage {
  6. void set_user(1: User user),
  7. User get_user(1: string id)
  8. }


在此目录下运行thrift命令,生成相应的java文件和ruby文件
生成java相关文件的命令:
Java代码 复制代码 收藏代码
  1. thrift -r -gen java user.thrift

生成ruby相关文件的命令:
Java代码 复制代码 收藏代码
  1. 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文件引入,下面开始实现服务
首先要实现那两个自定一个接口方法
Java代码 复制代码 收藏代码
  1. public class UserServiceHandlerimplements UserStorage.Iface {
  2. public void set_user(User user)throws TException {
  3. System.out.println(user.name + " " + user.id);
  4. }
  5. public User get_user(String id)throws TException {
  6. // 没有逻辑意义,纯粹是为了返回一个user
  7. User user = new User();
  8. user.setId(id);
  9. user.setName("user_one");
  10. return user;
  11. }
  12. }


启动java这边的服务
Java代码 复制代码 收藏代码
  1. public staticvoid main(String[] args) {
  2. try {
  3. UserServiceHandler handler = new UserServiceHandler();
  4. UserStorage.Processor processor = new UserStorage.Processor(handler);
  5. TServerTransport serverTransport = new TServerSocket(9090);
  6. TServer server = new TSimpleServer(processor, serverTransport);
  7. // Use this for a multithreaded server
  8. // server = new TThreadPoolServer(processor, serverTransport);
  9. System.out.println("Starting the server...");
  10. server.serve();
  11. } catch (TTransportException tTransportException) {
  12. }
  13. }


三 ruby客户端

Ruby代码 复制代码 收藏代码
  1. require 'thrift'
  2. require 'user_constants'
  3. require 'user_storage'
  4. transport = Thrift::BufferedTransport.new(Thrift::Socket.new('localhost', 5555))
  5. protocol = Thrift::BinaryProtocol.new(transport)
  6. client = UserStorage::Client.new(protocol)
  7. transport.open()
  8. user = client.get_user('123')
  9. p user



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