Thrift 简介:

Thrift 是一款高性能、开源的 RPC 框架,产自 Facebook 后贡献给了 Apache,Thrift 囊括了整个 RPC 的上下游体系,自带序列化编译工具,因为 Thrift 采用的是二进制序列化,并且与 gRPC 一样使用的都是长连接建立 client 与 server 之间的通讯,相比于比传统的使用XML,JSON,SOAP等短连接的解决方案性能要快得多。
本篇只介绍 Golang 关于 Thrift 的基础使用。

安装

  • 安装 Thrift 的 Golang 库有两种方案:

    1. 直接通过 go get 命令安装,缺点是因为不可抗拒的网络因素大部分人可能会失败:$ go get git.apache.org/thrift.git/lib/go/thrift
    2. 通过源码安装:
      • 在 $GOPATH 的 src 目录下创建多层级目录:git.apache.org/thrift.git/lib/go
      • 从 github 上下载 thrift 0.10.0 的源码 ,解压后进入 thrift-0.10.0/lib/go 目录下,将 thrift 目录 copy 到刚创建的 $GOPATH/src/git.apache.org/thrift.git/lib/go 目录下
      • 在任意目录下执行 $ go install git.apache.org/thrift.git/lib/go/thrift 就完成了 golang 的 thrift 库的安装
  • 安装 Thrift 的 IDL 编译工具(可省去)

    1. windows 平台下安装:

      直接下载:thrift complier 下载地址,下载完成后改名为:thrift.exe 并将其放入到系统环境变量下即可使用

    2. Linux 平台下安装:

      从 github 上下载 thrift 0.10.0 的源码,解压后进入:thrift-0.10.0/compiler/cpp 目录执行如下命令完成编译后,将其放入到系统环境变量下即可使用:
      $ mkdir cmake-build
      $ cd cmake-build
      $ cmake ..
      $ make

  • 验证是否安装成功:

    $ thrift -version,如果打印出来:Thrift version 0.10.0 表明 complier 安装成功

实践:

下面我们使用 Thrift 定义一个接口,该接口实现对传入的数据进行大写的格式化处理。

  • 创建 golang 项目 ThriftDemo 工程:

Paste_Image.png
  1. client目录下的 client.go 实现了客户端用于发送数据并打印接收到 server 端处理后的数据
  2. server 目录下的 server.go 实现了服务端用于接收客户端发送的数据,并对数据进行大写处理后返回给客户端
  3. thrift_file 用于存放 thrift 的 IDL 文件: *.thrift
  • 定义 Thrift RPC 接口

example.thrift:

namespace py example

struct Data {
: string text
} service format_data {
Data do_format(:Data data),
}
  • 编译 thrift 文件

    进入 thrift_file 目录执行:$ thrift -out .. --gen go example.thrift,就会在 thrift_file 的同级目录下生成 golang 的包:example,其中 format_data-remote 是生成的测试代码可以不用特别关注

Paste_Image.png
  • 实现 server 端:
package main

import (
"ThriftDemo/example"
"strings"
"git.apache.org/thrift.git/lib/go/thrift"
"fmt"
"log"
) type FormatDataImpl struct {} func (fdi *FormatDataImpl) DoFormat(data *example.Data) (r *example.Data, err error){
var rData example.Data
rData.Text = strings.ToUpper(data.Text) return &rData, nil
} const (
HOST = "localhost"
PORT = ""
) func main() { handler := &FormatDataImpl{}
processor := example.NewFormatDataProcessor(handler)
serverTransport, err := thrift.NewTServerSocket(HOST + ":" + PORT)
if err != nil {
log.Fatalln("Error:", err)
}
transportFactory := thrift.NewTFramedTransportFactory(thrift.NewTTransportFactory())
protocolFactory := thrift.NewTBinaryProtocolFactoryDefault() server := thrift.NewTSimpleServer4(processor, serverTransport, transportFactory, protocolFactory)
fmt.Println("Running at:", HOST + ":" + PORT)
server.Serve()
}
  • 实现 client 端
package main

import (
"git.apache.org/thrift.git/lib/go/thrift"
"net"
"fmt"
"ThriftDemo/example"
"log"
) const (
HOST = "localhost"
PORT = ""
) func main() {
tSocket, err := thrift.NewTSocket(net.JoinHostPort(HOST, PORT))
if err != nil {
log.Fatalln("tSocket error:", err)
}
transportFactory := thrift.NewTFramedTransportFactory(thrift.NewTTransportFactory())
transport := transportFactory.GetTransport(tSocket)
protocolFactory := thrift.NewTBinaryProtocolFactoryDefault() client := example.NewFormatDataClientFactory(transport, protocolFactory) if err := transport.Open(); err != nil {
log.Fatalln("Error opening:", HOST + ":" + PORT)
}
defer transport.Close() data := example.Data{Text:"hello,world!"}
d, err := client.DoFormat(&data)
fmt.Println(d.Text)
}
  • 执行验证结果:

    1. 先启动 server,之后再执行 client
    2. client 侧控制台如果打印的结果为: HELLO,WORLD! ,证明 Thrift 的 RPC 接口定义成功

最新文章

  1. STM32之EXTI——外部中断
  2. JSP JSTL EL
  3. Git使用总结
  4. SQL实现递归及存储过程中In()参数传递解决方案[转]
  5. HDU 3376 && 2686 方格取数 最大和 费用流裸题
  6. POJ1182食物链(并查集)
  7. Github经理和员工开发
  8. layui 重加载
  9. day 7-19 Mysql索引原理与查询优化
  10. Selenium如何在谷歌浏览器模拟H5页面
  11. Luogu P4462 [CQOI2018]异或序列
  12. JUnit报错 java.lang.Exception:No tests found matching
  13. 测试那些事儿—BUG
  14. [UE4]AIPerception,AI感知
  15. python 正则表达式 group() groups()
  16. 创建mysql数据库并指定编码
  17. 使用JSON语法创建JS对象(重要)
  18. Servlet------>mvc模式原理图
  19. Dell R720上的系统安装问题的解决办法(关于RAID建立磁盘阵列的技术)
  20. codevs 3287 货车运输 NOIP2013提高组

热门文章

  1. 经典的7种排序算法 原理C++实现
  2. Python学习笔记3(字典)
  3. perl的bareword
  4. Django中模板查找路径配置
  5. Verilog学习笔记基本语法篇(六)········ 循环语句
  6. js php 互调
  7. 正负无穷float('inf')的一些用法
  8. php 上传文件名出现乱码
  9. Python --链接Mongodb
  10. hdu2074