Thrift是一个服务端和客户端的架构体系


下图描绘了Thrift的整体架构,分为6个部分:

  1. 你的业务逻辑实现(You Code)          

  2. 客户端和服务端对应的Service    

  3. 执行读写操作的计算结果          

  4. 传输协议规范 TProtocol

  5. 传输数据标准 TTransports 

  6. 底层I/O通信


wKioL1PRuZGw8WIoAAEhjGq0mOE355.jpg



















  1. YourCode 你通过Thrift脚本文件生成的代码

  2. 图中的褐色框部分是你根据生成代码构建的客户端和处理器的代码,

  3. 图中红色的部分是2 端产生的计算结果。

  4. 从TProtocol下面3个部分是Thrift的传输体系和传输协议以及底层I/O通信,

    Thrift并且提供 堵塞、非阻塞,单线程、多线程的模式运行在服务器上,

    还可以配合服务器/容器一起运行,可以和现有JEE服务器/Web容器无缝的结合。


数据类型
     * Base Types:基本类型
     * Struct:结构体类型
     * Container:容器类型,即List、Set、Map
     * Exception:异常类型
     * Service: 定义对象的接口,和一系列方法

协议
     Thrift可以让你选择客户端与服务端之间传输通信协议的类别,在传输协议上总体上划分为文本  

      (text)和二进制(binary)传输协议, 为节约带宽,提供传输效率,一般情况下使用二进制类型的

      传输协议为多数,但有时会还是会使用基于文本类型的协议,这需要根据项目/产品中的实际需求


    * TBinaryProtocol – 二进制编码格式进行数据传输。


    * TCompactProtocol – 这种协议非常有效的,使用Variable-Length Quantity (VLQ) 编码

                           对数据进行压缩。


    * TJSONProtocol – 使用JSON的数据编码协议进行数据传输。


    * TSimpleJSONProtocol – 这种节约只提供JSON只写的协议,适用于通过脚本语言解析


    * TDebugProtocol – 在开发的过程中帮助开发人员调试用的,以文本的形式展现方便阅读。