Thrift-java学习小结
原文出自【听云技术博客】:http://blog.tingyun.com/web/article/detail/1083
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端的依赖中。
学习java知道这五个网站就够了 好吧,这很难反驳!如今,编程比以往任何时候都更加蓬勃发展,而且这种趋势预计只会增长。根据美国 code.org 的数据,未来 10 年计算机科学领域将有 140 万个工作岗位。编程技能将很快成为任何行业更高级别专业人员的标准要求,就像现在的 PC 用户技能一样。 因此,即使您不是 学软件的,而是未来的设计师、销售经理或营销策略师,熟悉编程也是一对你工作中有所帮助。
吐槽net下没有靠谱的FastDFS的sdk之使用thrift实现JAVA和C#互通 原文:吐槽net下没有靠谱的FastDFS的sdk之使用thrift实现JAVA和C#互通 事情是这样的,在一个新项目中引入了fastdfs,用这玩意做一些小数据的存储还是很方便的,然后在nuget上就找到了一个FastDFS的sdk,如下图: 一眼就看到了这个top1的sdk,应该会比较靠谱。
Thrift入门初探--thrift安装及java入门实例 公司的一些平台服务框架底层封装了thrift提供服务,最近项目不是很紧,于是研究了一下,刚刚入门,理解得不深,写这篇博文来整理一下思路. 什么是thrift? 简单来说,是Facebook公布的一款开源跨语言的RPC框架.
本文所使用的开发环境是windows环境,利用的资源是官网给出的,只是网上搜了很多文章,都不是很明白,我把我自己的经历写出来分享给大家,大家互相学习,有好的建议,希望不吝赐教
相关文章
- Tablesaw——Java统计、机器学习库
- 深入解析 Java集合类ArrayList与Vector的区别
- java中scanner意思_Java中的Scanner
- 如何在eclipse中导入java工程文件和java源代码文件
- 在线学习Java的几个网站,别再盲目学习java了![通俗易懂]
- java后端开发需要学什么_从事Java后端开发,要学习哪些知识和技能?[通俗易懂]
- java 汉字乱码_Java中文乱码问题
- java resourcebundle_Java – Properties和ResourceBundle类学习「建议收藏」
- 【JAVA面试必会】JMM高并发详解(java内存模型、JMM三大特征、volatile关键字 )「建议收藏」
- Java 基础学习(6)
- Java 基础学习(9)
- Java设计模式之享元模式
- java字符串练习题2、反向输出英文字符串
- 校园论坛(Java)—— 考研学习模块
- Java微服务框架一览详解架构师
- Java学习笔记之二十final关键字在Java继承中的用法小结详解编程语言
- 实现使用Java代码实现MySQL数据库连接(java连接mysql数据库代码)
- 学习如何使用Linux环境运行Java程序(linux下的java)
- Java多线程18:线程池详解编程语言
- Linux安装Java环境必备指南(linux装java)
- 实战探索:Java中使用Redis缓存(java的redis案例)
- 机制Redis在Java中实现过期机制(redisjava过期)
- 深入浅出 使用 Java 连接 Neo4j(java连接neo4j)
- Linux与Java调用C编程实战(linux java调c)
- Java Redis实例学习与应用(java redis实例)
- Novice:学习Java 7 在Linux上的简单入门(java 7 linux)
- Java编程实现MySQL数据库连接(java连mysql数据库)
- Java数据库之MySQL学习使用教程(mysql中java教程)
- Java与Oracle联手赋能全新版本面世(java版本oracle)
- JAVA/JSP学习系列之七