Reference:http://www.ibm.com/developerworks/cn/java/j-lo-apachethrift/

http://jacksongblack.blog.51cto.com/6378693/1175661

第一点

首先,说明一下windows环境下配置到运行的简单例子。

1. 官方下载thrift的exe文件;

2. 配置电脑的环境变量path,把thrift.exe所在的文件夹位置加入进去;

3. 如果配置成功,在cmd,命令thrift会有所提示。

到目前为止,电脑的环境配置完毕。

4. 在thrift文件所在的路径下执行thrift -r --gen rb hello.thrift。其中hello.thrift为项目的thrift文件。执行的结果就是:生成一个叫做gen-java的文件夹,里面就是你定义的接口。

此时,thrift文件转换完成。

第二点

Iface  eg. implements Hello.Iface

Client  eg. Hello.Client

Processor  eg. Hello.Processor

1. 用户实现的业务逻辑

2. 根据thrift定义的服务接口描述文件生成的客户端和服务器端代码框架

3. 根据thrift文件生成代码实现数据的读写操作

4. Thrift的传输体系、协议以及底层I/O通信

第三点(详细讲解:使用Thrift可以很方便的定义一个服务并且选择不同的传输协议传输层而不用重新生成代码)

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

  TBinaryProtocol - 二进制编码格式进行数据传输

  TCompactProtocol - 高效率的、密集的二进制编码格式进行数据传输

     TCompactProtocol.Factory proFactory = new TCompactProtocol.Factory();(Server)

     TCompactProtocol protocol = new TCompactProtocol(transport); (client)

  TJSONProtocol -使用JSON的数据编码协议进行数据传输

  TJSONProtocol =只提供JSON只写的协议,适用于通过脚本语言解析

2. 传输层:常用的传输层有以下几种

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

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

  TNonblocingTransport - 使用非阻塞方式,用于构建异步客户端

3. 服务器端类型

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

  TThreadPoolExecutor - 多线程服务器端使用标准的阻塞式I/O

  TNonblockingServer - 多线程服务器使用非阻塞式的I/O

4. 部署结构

HelloServiceClient->Hello.java(Hello.thrift, common libs: libthrift.jar, slf4j-api.jar)->HelloServiceServer.java(ServiceImplementation, helloServiceImpl.java)

客户端和服务器端部署时,需要用到公共的jar包和java文件

【thrift】初识thrift的更多相关文章

  1. 【thrift】thrift详解

    转载:http://zheming.wang/thrift-rpcxiang-jie.html Thrift Thrift是一个跨语言的服务部署框架,最初由Facebook于2007年开发,2008年 ...

  2. Thrift架构~thrift中间语言的认识(只有它什么都不是,它才有可能什么都是)

    中间语言是我为thrift语言起的名字,呵呵,为什么叫它中间语言呢,其实意思很简单,就是说,它只是一个过程,而不是一个最终的结果,而结果需要这个中间过程的影响,没有中间语言,结果语言也不能产生,在th ...

  3. 【thrift】thrift入门初探--thrift安装及java入门实例

    转载:https://www.cnblogs.com/fingerboy/p/6424248.html 公司的一些平台服务框架底层封装了thrift提供服务,最近项目不是很紧,于是研究了一下,刚刚入门 ...

  4. Java使用Thrift,Thrift结构体定义

    1.Thrift定义文件,Thrift常见的数据类型 1.基本类型(括号内为对应的Java类型): bool(boolean): 布尔类型(TRUE or FALSE) byte(byte): 8位带 ...

  5. 使用Vue和thrift建立前后端交互的demo

    初识thrift thrift 是 facebook 于2007年开发的一款跨平台 RPC(Remote Procedure Call) 软件框架, 它可以在多种平台上进行无缝交互,数据传输使用二进制 ...

  6. Thrift架构~目录

    回到占占推荐博客索引 概念相关 thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ru ...

  7. Thrift简单实践

    0.什么是RPC RPC(Remote Procedure Call - 远程过程调用),是通过网络从远程计算机上请求服务,而不需要了解底层网路技术的细节.简单点说,就是像调用本地服务(方法)一样调用 ...

  8. Thrift:Quick Start

    Thrift 快速开始 1 Thrift 介绍 目前流行的服务调用方式有很多种,例如基于 SOAP 消息格式的 Web Service,基于 JSON 消息格式的 RESTful 服务等.其中所用到的 ...

  9. thrift的lua实现

    最近要进行系统升级,后台的数据是根据城市区分的.担心新系统的稳定性及新数据的准确性,计划部分城市采用新接口.接口的入参里没有城市信息,只有经纬度坐标,需要调用一个thrift接口来根据坐标获取城市信息 ...

随机推荐

  1. 【转】 从输入 URL 到页面加载完成的过程中都发生了什么事情?

    该问题总结 一. 往浏览器输入URL后给你一个页面,你天天在使用的东西,学过计算机网络的知道是怎么回事,就DNS解析然后页面的回馈,不过要讲好还是有难度. 之前fex团队的nwind专门写过这个问题的 ...

  2. Hibernate框架中的HibernateUtil

    对于刚学习三层框架的人来说.每个配置文件和每个类.以及功能来说都非常新奇,时常就忘记了相关类的功能. 在这里建议编程就是要多加练习,才干熟能生巧. 这里说一下HibernateUtil类,在使用Hib ...

  3. HDU-1047-Integer Inquiry(Java大数水题 && 格式恶心)

    Integer Inquiry Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  4. 《Android源代码设计模式解析与实战》读书笔记

    1.定义 将对象组合成树形结构以表示"部分-总体"的层次结构,使得用户对单个对象和组合对象的使用具有一致性. 2.使用场景 (1)表示对象的部分-总体层次结构时. (2)从一个总体 ...

  5. 我是怎样理解web页面的

    事实上web页面包括三部分东东 1.页面展示的元素(HTML) 2.页面元素展示的样式(CSS) 3.控制页面元素的交互(JavaScript) 不管页面多么复杂,从这三方面去看,都会得到清晰的认识的 ...

  6. Android提供支持不同屏幕大小的各种方法

    1 http://blog.csdn.net/guolin_blog/article/details/8830286  (手机平板,通过large-layout来区分两条布局文件) 2 http:// ...

  7. rsync断点续传

    这经常是我们所说的镜像同步就是这么来的,如果断点续传呢?rsync完全可以做到这一点.man手册再次告诉我们: --partial      By default, rsync will delete ...

  8. Mongodb 的学习

    传送门: # 官方网站 及 下载地址 https://www.mongodb.com/download-center/enterprise/releases # 之前简单学习的笔记http://www ...

  9. 经常使用socket函数具体解释

    经常使用socket函数具体解释 关于socket函数,每一个的意义和基本功能都知道,但每次使用都会去百度,參数究竟是什么,返回值代表什么意义.就是说用的少,也记得不够精确. 每次都查半天.常常烦恼于 ...

  10. PHP高级工程师的要求

    PHP 高级工程师1名,(3年以上工作经验  )   1.熟悉unix环境编程,如多线程/多进程,IO复用.锁.定时器.新号.信号量.共享内存.消息队列.文件系统2.熟悉php的stream.sock ...