我用的是c++,所以我举一个c++的例子,简单说一下thrift的使用入门。
(1)书写.thrift文件
student.thrift文件内容如下:
struct Student{
1: i32 sno,
2: string sname,
3: bool ssex,
4: i16 sage,
}
service Serv{
void put(1: Student s),
}
(2)生成cpp文件
只需要一个thrift命令即可:
thrift -r --gen cpp student.thrift
--gen 后指定生成的语言,生成的cpp存储在目录gen-cpp下
此时 gen-cpp目录下有多个文件:Serv.cpp Serv.h Serv_server.skeleton.cpp student_constants.cpp student_constants.h student_types.cpp student_types.h
Serv开头的文件是由service生成的
这些文件可以进行编译,生成最初的服务端。
(3)编写客户端 client.cpp
#include </home/xiaodan/MyThriftTest/student/gen-cpp/Serv.h>
#include </usr/local/include/thrift/transport/TSocket.h>
#include </usr/local/include/thrift/transport/TBufferTransports.h>
#include </usr/local/include/thrift/protocol/TBinaryProtocol.h>
using namespace apache::thrift;
using namespace apache::thrift::protocol;
using namespace apache::thrift::transport;
using boost::shared_ptr;
int main(int argc, char **argv) {
boost::shared_ptr<TSocket> socket(new TSocket("localhost", 9090)); //注意此处的ip和端口
boost::shared_ptr<TTransport> transport(new TBufferedTransport(socket));
boost::shared_ptr<TProtocol> protocol(new TBinaryProtocol(transport));
transport->open();
// 我们的代码写在这里
transport->close();
return 0;
}
(4)编译服务器端和客户端
编译服务端:g++ -g -lthrift Serv.cpp student_types.cpp student_constants.cpp Serv_server.skeleton.cpp -o server
编译客户端:g++ -g -Ithrift -L -lm -pthread -lz -lrt -lssl gen-cpp/Serv.cpp gen-cpp/student_types.cpp gen-cpp/student_constants.cpp client.cpp -o client -lthrift
(5)启动客户端和服务器端
./server
./client
注意此时需要开启另一个窗口来开启客户端,因为服务端开启已经被占用
(6)传输我们的数据Student信息
我们把客户端client.cpp当做发送端,编写程序向服务端发送消息
在client.cpp中添加以下代码
transport->open(); //********添加部分*********** Student s; s.sno = 123; s.sname = "xiaoshe"; s.ssex = 1; s.sage = 30; ServClient client(protocol); client.put(s); //********添加部分*********** transport->close();
在类ServHandler()的put()中: void put(const Student& s) { // Your implementation goes here printf("put\n"); printf("sno=%d sname=%s ssex=%d sage=%d/n", s.sno, s.sname.c_str(), s.ssex, s.sage); //********次行为添加代码******** }
再次编译运行
1 启动./server
2 再另外窗口执行./client
3 查看server窗口,即可看到打印信息如下: