当前位置: 首页 > news >正文

Thrift-java学习小结

更多技术干货请戳:听云博客

Thrift是什么?什么情况下使用thrift

Thrift源于大名鼎鼎的facebook之手,在2007年facebook提交Apache基金会将Thrift作为一个开源项目,对于当时的facebook来说创造thrift是为了解决facebook系统中各系统间大数据量的传输通信以及系统之间语言环境不同需要跨平台的特性。所以thrift可以支持多种程序语言,例如:  C++, C#, Cocoa, Erlang, Haskell, Java, Ocami, Perl, PHP, Python, Ruby, Smalltalk. 在多种不同的语言之间通信thrift可以作为二进制的高性能的通讯中间件,支持数据(对象)序列化和多种类型的RPC服务。Thrift是IDL(interface definition language)描述性语言的一个具体实现,Thrift适用于程序对程序静态的数据交换,需要先确定好他的数据结构,他是完全静态化的,当数据结构发生变化时,必须重新编辑IDL文件,代码生成,再编译载入的流程,跟其他IDL工具相比较可以视为是Thrift的弱项,Thrift适用于搭建大型数据交换及存储的通用工具,对于大型系统中的子系统间数据传输相对于JSON和xml无论在性能、传输大小上有明显的优势。

Thrift 基础架构

Thrift是一个服务端和客户端的架构体系,就是socket传输,Thrift 具有自己内部定义的传输协议规范(TProtocol)和传输数据标准(TTransports),通过IDL脚本对传输数据的数据结构(struct) 和传输数据的业务逻辑(service)根据不同的运行环境快速的构建相应的代码,并且通过自己内部的序列化机制对传输的数据进行简化和压缩提高高并发、 大型系统中数据交互的成本,下图描绘了Thrift的整体架构,分为6个部分:1.你的业务逻辑实现(You Code) 2.客户端和服务端对应的Service 3.执行读写操作的计算结果4.TProtocol 5.TTransports  6.底层I/O通信

Thrift脚本的数据类型

 * Base Types:基本类型

bool        Boolean, one byte

byte        Signed byte

i16         Signed 16-bit integer

i32         Signed 32-bit integer

i64         Signed 64-bit integer

double      64-bit floating point value

string      String

binary      Blob (byte array)

 * Struct:结构体类型

 * Container:容器类型,即List、Set、Map

map<t1,t2> Map from one type to another

list<t1>    Ordered list of one type

set<t1>     Set of unique elements of one type

 * Exception:异常类型

 * Service: 定义对象的接口,和一系列方法

协议

  Thrift可以让你选择客户端与服务端之间传输通信协议的类别,在传输协议上总体上划分为文本(text)和二进制(binary)传输协议, 为节约带宽,提供传输效率,一般情况下使用二进制类型的传输协议为多数,但有时会还是会使用基于文本类型的协议,这需要根据项目/产品中的实际需求:

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

    * TCompactProtocol – 这种协议非常有效的,使用Variable-Length Quantity (VLQ) 编码对数据进行压缩。

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

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

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

传输层

    * TSocket- 使用堵塞式I/O进行传输,也是最常见的模式。

    * TFramedTransport- 使用非阻塞方式,按块的大小,进行传输,类似于Java中的NIO。

    * TFileTransport- 顾名思义按照文件的方式进程传输,虽然这种方式不提供Java的实现,但是实现起来非常简单。

    * TMemoryTransport- 使用内存I/O,就好比Java中的ByteArrayOutputStream实现。

    * TZlibTransport- 使用执行zlib压缩,不提供Java的实现。

服务端类型

    * TSimpleServer -  单线程服务器端使用标准的堵塞式I/O。

    * TThreadPoolServer -  多线程服务器端使用标准的堵塞式I/O。

    * TNonblockingServer – 多线程服务器端使用非堵塞式I/O,并且实现了Java中的NIO通道。

Thrift构建步骤总结(参考实例1)

1 、下载thrift.exe

到thrift官网下载,这里我用的是0.9.3版本

http://thrift.apache.org/

2、将exe放到C:\Windows下(重命名为thrift.exe)

3、C:\Windows创建.thrift文件,编写ThriftServer.thrift代码

4、在目录下执行thrift.exe -r -gen java ./ThriftServer.thrift;执行成功后看到在该目录下生成了gen-java文件夹,在该文件夹中生成了IThriftServer.java;

5、将IThriftServer.java拷贝到server端,进行后续编写即可。

6、如果client和server端是跨应用,那么需要server端先编译打包成jar,将这个jar添加到client端的依赖中。

 

原文链接:http://blog.tingyun.com/web/article/detail/1083

转载于:https://www.cnblogs.com/TingyunAPM/p/5710076.html

相关文章:

  • Flex:使用FlexPaper显示PDF文档
  • SWFObject2.0两种调用方式
  • 异构SOA系统架构之Asp.net实现(兼容dubbo)
  • Spring核心技术(十一)——基于Java的容器配置(一)
  • 让网站禁止某些邮箱的注册
  • oschina github使用指南
  • VC++ 命名空间
  • 数据库字段类型
  • C++对C的扩充(1)
  • JS中创建对象的方法及json
  • C++对C的扩充(2)
  • Chapter1-data access reloaded:Entity Framework(下)
  • 第四讲:面向对象程序设计方法及类、对象的概念
  • 第五讲:类的成员、对象成员的引用
  • Linux2.6内核--进程调度理论
  • 【Amaple教程】5. 插件
  • 【React系列】如何构建React应用程序
  • Hexo+码云+git快速搭建免费的静态Blog
  • Java精华积累:初学者都应该搞懂的问题
  • Spring Security中异常上抛机制及对于转型处理的一些感悟
  • Vue2.x学习三:事件处理生命周期钩子
  • Vue实战(四)登录/注册页的实现
  • web标准化(下)
  • WinRAR存在严重的安全漏洞影响5亿用户
  • 案例分享〡三拾众筹持续交付开发流程支撑创新业务
  • 第13期 DApp 榜单 :来,吃我这波安利
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 后端_ThinkPHP5
  • 机器学习中为什么要做归一化normalization
  • 微信小程序实战练习(仿五洲到家微信版)
  • 为什么要用IPython/Jupyter?
  • 云大使推广中的常见热门问题
  • const的用法,特别是用在函数前面与后面的区别
  • Java性能优化之JVM GC(垃圾回收机制)
  • kubernetes资源对象--ingress
  • Salesforce和SAP Netweaver里数据库表的元数据设计
  • ​人工智能之父图灵诞辰纪念日,一起来看最受读者欢迎的AI技术好书
  • ## 临床数据 两两比较 加显著性boxplot加显著性
  • #传输# #传输数据判断#
  • (附源码)计算机毕业设计ssm电影分享网站
  • (黑马出品_高级篇_01)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (转)Scala的“=”符号简介
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载
  • .Net 6.0 处理跨域的方式
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .net oracle 连接超时_Mysql连接数据库异常汇总【必收藏】
  • .NET 同步与异步 之 原子操作和自旋锁(Interlocked、SpinLock)(九)
  • .NET/C# 检测电脑上安装的 .NET Framework 的版本
  • .NET/C# 使窗口永不获得焦点
  • .NET序列化 serializable,反序列化
  • .NET中 MVC 工厂模式浅析
  • :not(:first-child)和:not(:last-child)的用法
  • @Conditional注解详解