简单thrift搭建

我用的是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窗口,即可看到打印信息如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值