Thrift的安装方法和简单实例
<p>本文只是简单的讲解Thrift开源框架的安装和简单使用示例,对于详细的讲解,后面在进行阐述。</p>
<p>
<span><strong>Thrift简述 </strong></span></p>
<p>
Thrift是一款由Fackbook开发的可伸缩、跨语言的服务开发框架,该框架已经开源并且加入的Apache项目。Thrift主要功能是:通过自定义的Interface Definition Language(IDL),可以创建基于RPC的客户端和服务端的服务代码。服务代码的生成是通过Thrift内置的代码生成器来实现的。Thrift 的跨语言性体现在,它可以生成C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, OCaml , Delphi等语言的代码,且它们之间可以进行透明的通信。</p>
<p>
<span><strong>Thrift的安装 </strong></span></p>
<p>
安装版本为:Thrift v0.9.1</p>
<p>
系统版本:Ubuntu 14.04 64位</p>
<p>
<span><strong>基本安装环境:</strong></span></p>
<p>
g++ 4.2<br>
boost 1.53.0<br>
libssl-dev</p>
<p>
Thrift的编译器即代码生成器是由C++编写的,所以需要g++来进行编译安装,且Thrift源码中用到了boost库中相关实现,例如shared_ptr,所以要事先安装boost库。</p>
<p>
Thrift通信过程中使用ssl对数据进行安全包含,如果为安装该库,会在configure时出现configure: error: "Error: libcrypto required."</p>
<p>
Thrift提供了,TThreadSever, TThreadPoolServer, TNonblockingServer四种服务器框架,TSimpleServer以单一主线程阻塞的方式进行事件处理,TThreadPoolServer以多线程阻塞的方式提供服务,TNonblockingServer以多线程非阻塞方式工作。 TNonblockingServer服务模型的使用需要事先安装libevent,libevent-dev库,libevent是异步事件处理的程序库,其包含我们常用的poll,select,epoll等异步处理函数。</p>
<p>
<span><strong>安装步骤:</strong></span></p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_188210">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">$./configure </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">$make </code>
</div>
<div class="line number3 index2 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">#sudo make install</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
configure的结果最后一部分如下,其中<strong>Build TNonblockingServer .. : yes</strong>的结果对于使用异步的服务器模型是必须的。</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_909558">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
<div class="line number21 index20 alt2">
21</div>
<div class="line number22 index21 alt1">
22</div>
<div class="line number23 index22 alt2">
23</div>
<div class="line number24 index23 alt1">
24</div>
<div class="line number25 index24 alt2">
25</div>
<div class="line number26 index25 alt1">
26</div>
<div class="line number27 index26 alt2">
27</div>
<div class="line number28 index27 alt1">
28</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">anonymalias@anonymalias-Rev-1-0:~/download/thrift-0.9.1$./configure </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml plain">...... </code>
</div>
<div class="line number3 index2 alt2">
<code class="xhtml plain">thrift 0.9.1 </code>
</div>
<div class="line number4 index3 alt1">
<code class="xhtml spaces"> </code>
</div>
<div class="line number5 index4 alt2">
<code class="xhtml plain">Building C++ Library ......... : yes </code>
</div>
<div class="line number6 index5 alt1">
<code class="xhtml plain">Building C (GLib) Library .... : no </code>
</div>
<div class="line number7 index6 alt2">
<code class="xhtml plain">Building Java Library ........ : no </code>
</div>
<div class="line number8 index7 alt1">
<code class="xhtml plain">Building C# Library .......... : no </code>
</div>
<div class="line number9 index8 alt2">
<code class="xhtml plain">Building Python Library ...... : yes </code>
</div>
<div class="line number10 index9 alt1">
<code class="xhtml plain">Building Ruby Library ........ : no </code>
</div>
<div class="line number11 index10 alt2">
<code class="xhtml plain">Building Haskell Library ..... : no </code>
</div>
<div class="line number12 index11 alt1">
<code class="xhtml plain">Building Perl Library ........ : no </code>
</div>
<div class="line number13 index12 alt2">
<code class="xhtml plain">Building PHP Library ......... : no </code>
</div>
<div class="line number14 index13 alt1">
<code class="xhtml plain">Building Erlang Library ...... : no </code>
</div>
<div class="line number15 index14 alt2">
<code class="xhtml plain">Building Go Library .......... : no </code>
</div>
<div class="line number16 index15 alt1">
<code class="xhtml plain">Building D Library ........... : no </code>
</div>
<div class="line number17 index16 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number18 index17 alt1">
<code class="xhtml plain">C++ Library: </code>
</div>
<div class="line number19 index18 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">Build TZlibTransport ...... : yes </code>
</div>
<div class="line number20 index19 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">Build TNonblockingServer .. : yes </code>
</div>
<div class="line number21 index20 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">Build TQTcpServer (Qt) .... : no </code>
</div>
<div class="line number22 index21 alt1">
<code class="xhtml spaces"> </code>
</div>
<div class="line number23 index22 alt2">
<code class="xhtml plain">Python Library: </code>
</div>
<div class="line number24 index23 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">Using Python .............. : /usr/bin/python </code>
</div>
<div class="line number25 index24 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number26 index25 alt1">
<code class="xhtml plain">If something is missing that you think should be present, </code>
</div>
<div class="line number27 index26 alt2">
<code class="xhtml plain">please skim the output of configure to find the missing </code>
</div>
<div class="line number28 index27 alt1">
<code class="xhtml plain">component. Details are present in config.log.</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
在本人电脑上make的时候会出现下面的bug,</p>
<p>
<span><strong>ar: .libs/ThriftTest_constants.o: No such file or directory</strong></span></p>
<p>
不知道Makefile如何生成的,导致上面这个编译文件路径有问题,解决方法有下面两种:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_118136">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">method1: </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml plain">解决的方法时直接从Github(git://git.apache.org/thrift.git)上git clone 源码,先运行./bootstrap.sh,在按照configure安装。 </code>
</div>
<div class="line number3 index2 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number4 index3 alt1">
<code class="xhtml plain">method2: </code>
</div>
<div class="line number5 index4 alt2">
<code class="xhtml plain">可以将已经编译的test/cpp/*.o复制到test/cpp/.libs后,继续编译就可以了 </code>
</div>
<div class="line number6 index5 alt1">
<code class="xhtml plain">cp test/cpp/*.o test/cpp/.libs/</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<span><strong>Thrift的简单示例 </strong></span></p>
<p>
首先创建Thrift的语法规则文件,命名为server.thrift,内容如下:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_834057">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">struct message </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml plain">{ </code>
</div>
<div class="line number3 index2 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">1:i32 seqId, </code>
</div>
<div class="line number4 index3 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">2:string content </code>
</div>
<div class="line number5 index4 alt2">
<code class="xhtml plain">} </code>
</div>
<div class="line number6 index5 alt1">
<code class="xhtml spaces"> </code>
</div>
<div class="line number7 index6 alt2">
<code class="xhtml plain">service serDemo </code>
</div>
<div class="line number8 index7 alt1">
<code class="xhtml plain">{ </code>
</div>
<div class="line number9 index8 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">void put(1:message msg) </code>
</div>
<div class="line number10 index9 alt1">
<code class="xhtml plain">}</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
在shell下面执行执行:<br>
<br><span><strong>thrift -gen cpp server.thrift </strong></span></p>
<p>
该语句用于创建c++服务框架,创建成功后会在该目录下生成gen-cpp文件夹,然后修改该目录下的serDemo_server.skeleton.cpp,在put函数中添加如下代码:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_691495">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">class serDemoHandler : virtual public serDemoIf { </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">public: </code>
</div>
<div class="line number3 index2 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">serDemoHandler() { </code>
</div>
<div class="line number4 index3 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">// Your initialization goes here </code>
</div>
<div class="line number5 index4 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">} </code>
</div>
<div class="line number6 index5 alt1">
<code class="xhtml spaces"> </code>
</div>
<div class="line number7 index6 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">void put(const message& msg) { </code>
</div>
<div class="line number8 index7 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">// Your implementation goes here </code>
</div>
<div class="line number9 index8 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">printf("receive message: id: %d, content: %s\n", msg.seqId, msg.content.c_str()); </code>
</div>
<div class="line number10 index9 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">}</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
然后进行编译就可以了<strong>:g++ -o server *.cpp -lthrift</strong></p>
<p>
上面是server框架的代码,对于client的框架其实已经创建,但是现在需要添加client执行代码,可以在该目录下创建client.cpp,然后输入以下内容,下面的内容可以作为SimpleServer的client的模板,只需修改注释的部分。</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_670277">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
<div class="line number21 index20 alt2">
21</div>
<div class="line number22 index21 alt1">
22</div>
<div class="line number23 index22 alt2">
23</div>
<div class="line number24 index23 alt1">
24</div>
<div class="line number25 index24 alt2">
25</div>
<div class="line number26 index25 alt1">
26</div>
<div class="line number27 index26 alt2">
27</div>
<div class="line number28 index27 alt1">
28</div>
<div class="line number29 index28 alt2">
29</div>
<div class="line number30 index29 alt1">
30</div>
<div class="line number31 index30 alt2">
31</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">// -------------------------替换成对应service名字的.h 文件------------------------ </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml plain">#include "SerDemo.h" </code>
</div>
<div class="line number3 index2 alt2">
<code class="xhtml plain">//------------------------------------------------------------------------------ </code>
</div>
<div class="line number4 index3 alt1">
<code class="xhtml plain">#include <</code><code class="xhtml keyword">transport</code><code class="xhtml plain">/TSocket.h> </code>
</div>
<div class="line number5 index4 alt2">
<code class="xhtml plain">#include <</code><code class="xhtml keyword">transport</code><code class="xhtml plain">/TBufferTransports.h> </code>
</div>
<div class="line number6 index5 alt1">
<code class="xhtml plain">#include <</code><code class="xhtml keyword">protocol</code><code class="xhtml plain">/TBinaryProtocol.h> </code>
</div>
<div class="line number7 index6 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number8 index7 alt1">
<code class="xhtml plain">using namespace apache::thrift; </code>
</div>
<div class="line number9 index8 alt2">
<code class="xhtml plain">using namespace apache::thrift::protocol; </code>
</div>
<div class="line number10 index9 alt1">
<code class="xhtml plain">using namespace apache::thrift::transport; </code>
</div>
<div class="line number11 index10 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number12 index11 alt1">
<code class="xhtml plain">using boost::shared_ptr; </code>
</div>
<div class="line number13 index12 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number14 index13 alt1">
<code class="xhtml plain">int main(int argc, char **argv) { </code>
</div>
<div class="line number15 index14 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">boost::shared_ptr<</code><code class="xhtml keyword">TSocket</code><code class="xhtml plain">> socket(new TSocket("localhost", 9090)); </code>
</div>
<div class="line number16 index15 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">boost::shared_ptr<</code><code class="xhtml keyword">TTransport</code><code class="xhtml plain">> transport(new TBufferedTransport(socket)); </code>
</div>
<div class="line number17 index16 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">boost::shared_ptr<</code><code class="xhtml keyword">TProtocol</code><code class="xhtml plain">> protocol(new TBinaryProtocol(transport)); </code>
</div>
<div class="line number18 index17 alt1">
<code class="xhtml spaces"> </code>
</div>
<div class="line number19 index18 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">transport->open(); </code>
</div>
<div class="line number20 index19 alt1">
<code class="xhtml spaces"> </code>
</div>
<div class="line number21 index20 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">// ----------------------------我们的代码写在这里------------------------------ </code>
</div>
<div class="line number22 index21 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">message msg; </code>
</div>
<div class="line number23 index22 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">msg.seqId = 1; </code>
</div>
<div class="line number24 index23 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">msg.content = "client message"; </code>
</div>
<div class="line number25 index24 alt2">
<code class="xhtml spaces"> </code><code class="xhtml plain">client.put(msg); </code>
</div>
<div class="line number26 index25 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">//-------------------------------------------------------------------------- </code>
</div>
<div class="line number27 index26 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number28 index27 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">transport->close(); </code>
</div>
<div class="line number29 index28 alt2">
<code class="xhtml spaces"> </code>
</div>
<div class="line number30 index29 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">return 0; </code>
</div>
<div class="line number31 index30 alt2">
<code class="xhtml plain">}</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
然后进行编译:<span><strong>g++ -o client *[^n].cpp - lthrift</strong></span>,也可以将<span><strong>serDemo_server.skeleton.cpp</strong></span>移动到其它目录,使用<span><strong>g++ -o client *.cpp - lthrift</strong></span>命令。</p>
<p>
然后就可以执行了,启动server后,启动client,server执行如下:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterxhtml" id="highlighter_687711">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="xhtml plain">anonymalias@anonymalias-Rev-1-0:~/code/thriftSerDemo/gen-cpp$ ./server </code>
</div>
<div class="line number2 index1 alt1">
<code class="xhtml spaces"> </code><code class="xhtml plain">receive message: id: 1, content: client message</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
以上就是小编为大家带来的Thrift的安装方法和简单实例全部内容了,希望大家多多支持~</p>
頁:
[1]