一、ubuntu下thrift的安装

1.下载源代码
http://thrift.apache.org/download/

下载最新版本thrift-0.8.0.tar.gz
2.安装boost库
sudo apt-get install libboost-dev libboost-dbg libboost-doc bcp libboost-*
3.安装其他相关工具包
sudo apt-get install libboost-dev libboost-test-dev libboost-program-options-dev libevent-dev automake libtool flex bison pkg-config g++ libssl-dev ant
如果需要支持java,需要安装jdk,配置java环境变量。
4.解压文件,进入目录thrift-0.8.0安装

./configure --with-cpp--with-boost--without-python--without-csharp --with-java --without-erlang --without-perl --with-php --without-php_extension --without-ruby --without-haskell--without-go

make
sudo make install
要支持java,需要编译生成jar包,到lib/java目录下,执行ant命令。将在lib/java/build目录下生成libthrift-0.8.0.jar和libthrift-0.8.0-javadoc.jar。编译过程中,可能出错,需要检查lib/java/build/tools/maven-ant-tasks-2.1.3.jar是否正确下载。
5.测试
直接输入thrift命令,看是否有用法提示 

二、thrift自带的测试样例
进入tutorial文件夹,shared.thrift和tutorial.thrift是接口定义文件。
thrift -r --gen java tutorial.thrift
thirft -r --gen cpp tutorial.thrift
执行这两条命令可以生成gen-java和gen-cpp两个文件夹,这些是thrift编译器自动生成的代码。
然后到java目录下,执行ant命令,编译成功后,在两个不同的窗口下执行以下命令:
./JavaServer
./JavaClient simple
进入cpp目录下,执行make命令,如果编译出错,第一个错误是
/usr/local/include/thrift/protocol/TBinaryProtocol.tcc:147:35: error: there are no arguments to ‘htons’ that depend on a template parameter, so a declaration of ‘htons’ must be available
则修改Makefile,加上编译选项-DHAVE_NETINET_IN_H
server: CppServer.cpp
g++ -DHAVE_NETINET_IN_H -o CppServer -I${THRIFT_DIR} -I${BOOST_DIR}  -I../gen-cpp -L${LIB_DIR} -lthrift CppServer.cpp ${GEN_SRC}
client: CppClient.cpp
g++ -DHAVE_NETINET_IN_H -o CppClient -I${THRIFT_DIR} -I${BOOST_DIR}  -I../gen-cpp -L${LIB_DIR} -lthrift CppClient.cpp ${GEN_SRC}

编译通过生,将生成CppClient和CppServer两个可执行程序。同样,在两个不同的窗口执行以下命令:
./CppServer
./CppClient
而且java和c++的Client和Server都可以交叉运行。比如运行JavaServer和CppClient也能得到同样的结果。以此达到了多语言的相互调用。
三、Hello World
仿照tutorial,写一个简单的hello world。在tutorial平级目录下,建立目录hello,这里只是为了测试需要。
服务端用java,客户端用java和c++。
1. 编写tt.thrift
namespace java demo
namespace cpp demo
service Hello{
string helloString(1:string para)
}

2. 编译生成代码
thrift -r --gen java tt.thrift
thrift -r --gen cpp tt.thrift
生成gen-java和gen-cpp两个文件夹
gen-cpp下有如下文件
Hello.cpp  Hello.h  Hello_server.skeleton.cpp  tt_constants.cpp  tt_constants.h  tt_types.cpp  tt_types.h
其中Hello.h,Hello.cpp中定义了远程调用的接口,实现了底层通信。可以在Hello.h中找到客户端远程调用需要用到的类HelloClient,调用方法:
void helloString(std::string& _return, const std::string& para);
这个跟thrift文件中申明的方法有点不一定,返回参数是通过引用传回来的。
Hello_server.skeleton.cpp将实现Hello.h的服务端接口,如果要用c++作为服务端,还需要将这个文件拷出去,重命名,实现类HelloHandler的方法helloString,远程调用方法的业务逻辑也就写在helloString中。可能还需要改main函数中的端口信息。
gen-java/demo下只有Hello.java一个文件,它定义了服务端和客户端的接口,实现了底层的通信。
3. 编写java服务端和客户端
仿照tutorial,在hello目录下建立java目录,将tutorial/java/下的一些文件和目录拷到hello/java下
build.xml JavaClient  JavaServer  src
删除src下所有文件,在src下编写代码。
1) HelloImpl.java 远程过程调用的业务逻辑
import demo.*;
import org.apache.thrift.TException;
class HelloImpl implements Hello.Iface {
public HelloImpl() {}
public String helloString(String para) throws org.apache.thrift.TException {
//各种业务逻辑
return "hello " + para;
}
}

2) Server.java  服务端程序
import demo.*;
import java.io.IOException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TBinaryProtocol.Factory;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TThreadPoolServer.Args;
import org.apache.thrift.server.TThreadPoolServer;
import org.apache.thrift.transport.TServerSocket;
import org.apache.thrift.transport.TTransportException;
public class Server {
private void start() {
try {
TServerSocket serverTransport = new TServerSocket(7911);
Hello.Processor processor = new Hello.Processor(new HelloImpl());
Factory protFactory = new TBinaryProtocol.Factory(true, true);
Args args = new Args(serverTransport);
args.processor(processor);
args.protocolFactory(protFactory);
TServer server = new TThreadPoolServer(args);
//TServer server = new TThreadPoolServer(processor, serverTransport, protFactory);
System.out.println("Starting server on port 7911 ...");
server.serve();

} catch (TTransportException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String args[]) {
Server srv = new Server();
srv.start();
}
}

3) Client.java 客户端程序
import demo.*;
import java.io.IOException;
import org.apache.thrift.*;
import org.apache.thrift.protocol.*;
import org.apache.thrift.transport.*;
public class Client {
public static void main(String [] args) {
try {
TTransport transport = new TSocket("localhost", 7911);
TProtocol protocol = new TBinaryProtocol(transport);
Hello.Client client = new Hello.Client(protocol);
transport.open();
System.out.println("Client calls hello");
System.out.println(client.helloString("world"));
transport.close();
} catch (TException x) {
x.printStackTrace();
}
}
}

4) 修改 build.xml
<project name="hello" default="hello" basedir=".">
<description>Thrift Hello</description>
<property name="src" location="src" />
<property name="gen" location="../gen-java" />
<property name="build" location="build" />
<path id="libs.classpath">
<fileset dir="http://www.cnblogs.com/lib/java/build">
<include name="*.jar" />
<exclude name="-test.jar" />
</fileset>
<fileset dir="http://www.cnblogs.com/lib/java/build/lib">
<include name="*.jar" />
</fileset>
</path>
<path id="build.classpath">
<path refid="libs.classpath" />
<pathelement path="${gen}" />
</path>
<target name="init">
<tstamp />

<mkdir dir="${build}"/>
</target>
<target name="compile" depends="init">
<javac srcdir="${gen}" destdir="${build}" classpathref="libs.classpath" />
<javac srcdir="${src}" destdir="${build}" classpathref="build.classpath" />
</target>
<target name="hello" depends="compile">
<jar jarfile="hello.jar" basedir="${build}"/>
</target>
<target name="clean">
<delete dir="${build}" />
<delete file="hello.jar" />
</target>
</project>

5) 编译
ant
将生成build文件夹
Client.class  demo  hello  HelloImpl.class  hello.jar  Server.class
6) 修改执行脚本
JavaClient
java -cp http://www.cnblogs.com/lib/java/build/lib/*:http://www.cnblogs.com/lib/java/build/*:hello.jar Client
JavaServer
java -cp http://www.cnblogs.com/lib/java/build/lib/*:http://www.cnblogs.com/lib/java/build/*:hello.jar Server
4. 编写c++客户端
同样仿照tutorial,将tutorial/cpp中的Makefile和CppClient.cpp拷到hello/cpp下。
1) 将CppClient.cpp重命名为Client.cpp,并修改
#include <stdio.h>
#include <unistd.h>
#include <sys/time.h>
#include <protocol/TBinaryProtocol.h>
#include <transport/TSocket.h>
#include <transport/TTransportUtils.h>
#include "../gen-cpp/Hello.h"
#include <string>
using namespace std;
using namespace apache::thrift;
using namespace apache::thrift::protocol;
using namespace apache::thrift::transport;
using namespace demo;
using namespace boost;
int main(int argc, char** argv) {
shared_ptr<TTransport> socket(new TSocket("localhost", 7911));
shared_ptr<TTransport> transport(new TBufferedTransport(socket));
shared_ptr<TProtocol> protocol(new TBinaryProtocol(transport));

HelloClient client(protocol);
try {
transport->open();
string ret;
client.helloString(ret, "world");
printf("%s\n", ret.c_str());
transport->close();
} catch (TException &tx) {
printf("ERROR: %s\n", tx.what());
}
}

2). 修改Makefile
BOOST_DIR = /usr/local/boost/include/boost-1_33_1/
THRIFT_DIR = /usr/local/include/thrift
LIB_DIR = /usr/local/lib
GEN_SRC = ../gen-cpp/tt_types.cpp ../gen-cpp/Hello.cpp
default: client
client: Client.cpp
g++ -DHAVE_NETINET_IN_H-o client -I${THRIFT_DIR} -I${BOOST_DIR}  -I../gen-cpp -L${LIB_DIR} -lthrift Client.cpp ${GEN_SRC}
clean:
$(RM) -r client

3). 编译
make
生成可执行文件client
5. 运行程序
运行服务端程序,java目录下:./JavaServer
运行客户端程序,cpp目录下:./client
这样c++程序通过 client.helloString(ret, "client") 可以调用服务端的java接口String helloString(String para)。
从而实现了远程多语言调用。

转载于:https://www.cnblogs.com/hitwtx/archive/2012/02/10/2345272.html

thrift (转)相关推荐

  1. Windows系统下安装Thrift的方法

    安装 下载 下载地址:http://archive.apache.org/dist/thrift/0.13.0/ 将thrift-0.13.0.exe放到一个文件下,如F:\thrift下,将其重命名 ...

  2. Thrift的服务器和客户端Python案例

    服务器 Thrift提供的常见服务端类型有一下几种: thrift.server.TServer.TSimpleServer 单线程服务器 thrift.server.TServer.TThreade ...

  3. Thrift协议与传输选择

    1 协议 Thrift 可以让用户选择客户端与服务端之间传输通信的消息协议类别,如我们前面所讲总体划分为文本 (text) 和二进制 (binary) ,为节约带宽,提高传输效率,一般情况下使用二进制 ...

  4. Thrift的接口定义语言IDL

    Thrift的IDL可以使用下面的语法来定义描述接口. 1 基本类型 bool:布尔值,true 或 false byte:8 位有符号整数 i16:16 位有符号整数 i32:32 位有符号整数 i ...

  5. CentOS7:Thrift的安装

    使用Thrift需要进行安装,主要安装两个工具: 接口定义文件(.thrift)的编译器 不同语言的公共基础库程序 1 安装依赖工具和库 yum install automake libtool fl ...

  6. Thrift架构与使用方法

    Thrift是由Facebook为"大规模跨语言服务开发"而开发的,现在是Apache软件基金会的开源项目. Thrift实现了一种接口描述语言和二进制通讯协议,用来定义和创建跨语 ...

  7. apache thrift分析

    thrift是一个用来实现跨语言的远程调用(RPC Remote Procedure Call)的软件框架.根据接口定义语言(IDL Interface definition lanuage) 并借助 ...

  8. php thrift 报错,thrift安装遇到的问题以及解决方法(必看篇)

    1. 必须安装boost.最新的稳定版是1.48.0. 1.1.先下载:http://sourceforge.NET/projects/boost/files/boost/1.48.0/ 选择tar. ...

  9. windows下rpc框架thrift的环境配置

    windows下rpc框架thrift的环境配置 引用链接: https://www.cnblogs.com/49er/p/7193829.html 最近在弄windows下 的Facebook的rp ...

  10. Thrift源码解析--TBinaryProtocol

    本文为原创:http://www.cnblogs.com/leehfly/p/4958206.html,未经许可禁止转载. 关于Tprotocol层都是一些通信协议,个人感觉内容较大,很难分类描述清楚 ...

最新文章

  1. [译] JWT 与 Spring Cloud 微服务
  2. 聊聊职场那些事儿(转)
  3. sharepoint 2010项目中,ashx页面获取SPContext.Current 为null的原因和解决方法
  4. php获取当前周得周一_PHP怎样获得最近一个周一和上周一的日期?
  5. Win10 + Python + MXNet + VS2015配置
  6. b tree和b+tree_B TREE实施
  7. 软考网络工程师学习笔记6-无线通信网
  8. Java生成CSV文件的方法
  9. 大数据入门教程系列之Hbase安装(伪分布式)
  10. 求长方形和正方形的面积
  11. etf基金代码大全_ETF赚钱丨什么是ETF?知道这三点就入门了!
  12. 【双足轮机器人】Ascento技术详解--(1)摘要和引言(2)系统描述【翻译】
  13. pycharm安装redis
  14. 【柒穆雨】平面设计好不好学?设计小白该如何学习平面设计
  15. 阿里云盘帮我扩容了10个T,拿来吧你!
  16. Node.js npm 使用介绍
  17. 容器部署在物理机还是虚拟机上?
  18. wordpress友联_WordPress如何添加友情链接
  19. Sublime Text介绍
  20. Cache与主存的地址映像

热门文章

  1. mysql数据库过滤数据_MySQL数据库常规操作一些简单绕过过滤的方法
  2. 2017-2018-1 20155339 《信息安全系统设计基础》第8周学习总结
  3. win7 64的系统安装。net4.0总是提示安装未成功
  4. Android 接收短信
  5. eclipse不格式化注释
  6. jQuery1.3以上版本@的问题
  7. web 页面间传值 js 封装方法
  8. SecureCRT连接虚拟机中的Linux系统
  9. Laravel项目问题集锦
  10. android中include标签使用详解