欢迎来到天天文库
浏览记录
ID:37315201
大小:120.69 KB
页数:9页
时间:2019-05-21
《thrift学习小结》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、Thrift-java学习小结Thrift是什么?什么情况下使用thriftThrift源于大名鼎鼎的facebook之手,在2007年facebook提交Apache基金会将Thrift作为一个开源项目,对于当时的facebook来说创造thrift是为了解决facebook系统中各系统间大数据量的传输通信以及系统之间语言环境不同需要跨平台的特性。所以thrift可以支持多种程序语言,例如: C++,C#,Cocoa,Erlang,Haskell,Java,Ocami,Perl,PHP,Python,R
2、uby,Smalltalk.在多种不同的语言之间通信thrift可以作为二进制的高性能的通讯中间件,支持数据(对象)序列化和多种类型的RPC服务。Thrift是IDL(interfacedefinitionlanguage)描述性语言的一个具体实现,Thrift适用于程序对程序静态的数据交换,需要先确定好他的数据结构,他是完全静态化的,当数据结构发生变化时,必须重新编辑IDL文件,代码生成,再编译载入的流程,跟其他IDL工具相比较可以视为是Thrift的弱项,Thrift适用于搭建大型数据交换及存储的通用
3、工具,对于大型系统中的子系统间数据传输相对于JSON和xml无论在性能、传输大小上有明显的优势。Thrift基础架构Thrift是一个服务端和客户端的架构体系,就是socket传输,Thrift具有自己内部定义的传输协议规范(TProtocol)和传输数据标准(TTransports),通过IDL脚本对传输数据的数据结构(struct)和传输数据的业务逻辑(service)根据不同的运行环境快速的构建相应的代码,并且通过自己内部的序列化机制对传输的数据进行简化和压缩提高高并发、大型系统中数据交互的成本,下
4、图描绘了Thrift的整体架构,分为6个部分:1.你的业务逻辑实现(YouCode)2.客户端和服务端对应的Service3.执行读写操作的计算结果4.TProtocol5.TTransports 6.底层I/O通信Thrift脚本的数据类型 *BaseTypes:基本类型boolBoolean,onebytebyteSignedbytei16Signed16-bitintegeri32Signed32-bitintegeri64Signed64-bitintegerdouble64-bitfloatin
5、gpointvaluestringStringbinaryBlob(bytearray) *Struct:结构体类型 *Container:容器类型,即List、Set、MapmapMapfromonetypetoanotherlistOrderedlistofonetypesetSetofuniqueelementsofonetype*Exception:异常类型 *Service:定义对象的接口,和一系列方法协议 Thrift可以让你选择客户端与服务端之间传输通信协议的类
6、别,在传输协议上总体上划分为文本(text)和二进制(binary)传输协议,为节约带宽,提供传输效率,一般情况下使用二进制类型的传输协议为多数,但有时会还是会使用基于文本类型的协议,这需要根据项目/产品中的实际需求: *TBinaryProtocol–二进制编码格式进行数据传输。 *TCompactProtocol–这种协议非常有效的,使用Variable-LengthQuantity(VLQ)编码对数据进行压缩。 *TJSONProtocol–使用JSON的数据编码协议进行数据传输。
7、*TSimpleJSONProtocol–这种节约只提供JSON只写的协议,适用于通过脚本语言解析 *TDebugProtocol–在开发的过程中帮助开发人员调试用的,以文本的形式展现方便阅读。传输层 *TSocket-使用堵塞式I/O进行传输,也是最常见的模式。 *TFramedTransport-使用非阻塞方式,按块的大小,进行传输,类似于Java中的NIO。 *TFileTransport-顾名思义按照文件的方式进程传输,虽然这种方式不提供Java的实现,但是实现起来非常简单。
8、*TMemoryTransport-使用内存I/O,就好比Java中的ByteArrayOutputStream实现。 *TZlibTransport-使用执行zlib压缩,不提供Java的实现。服务端类型 *TSimpleServer- 单线程服务器端使用标准的堵塞式I/O。 *TThreadPoolServer- 多线程服务器端使用标准的堵塞式I/O。 *TNonblockingServer–多线程服务器端
此文档下载收益归作者所有