Apache Thrift 白皮书
介绍:
轻量级、跨语言。
简洁的抽象和实现:数据传输、序列化、应用逻辑处理。
IDL及代码生成系统。
基本架构图如下:

28种语言支持:28 programming languages。
支持客户端及服务端版本非原子性升级。
一、IDL
1、基本数据类型:
• bool A boolean value, true or false
• byte A signed byte
• i16 A 16-bit signed integer
• i32 A 32-bit signed integer
• i64 A 64-bit signed integer
• double A 64-bit floating point number
• string An encoding-agnostic text or binary string
2、Structs:通用对象
等同于面向对象语言中的类。
struct Example {
1:i32 number=10,
2:i64 bigNumber
}
3、Containers 容器:
list<>、set<>、map<,>
4、Exceptions 异常:
等同于Structs,区别定义。
5、Services 服务定义:
等同于接口定义(或面型对象语言中的虚拟类)。
基本定义:
service <service-name> {
<return-type> <method-name>() [throws (<exceptions>)]
...
}
示例:
service StringCache {
void set(1:i32 key, 2:string value),
string get(1:i32 key) throws (1:KeyNotFound knf),
void delete(1:i32 key)
}
二、Transport
数据传输
1、接口 TTransport:代码生层及数据传输解耦,主要方法定义如下
• open Opens the tranpsort
• close Closes the tranport
• isOpen Indicates whether the transport is open
• read Reads from the transport
• write Writes to the transport
• flush Forces any pending writes
TServerTransport:接受或创建Transport对象。
2、实现
TSocket:TCP/IP数据流操作。
TFileTransport:文件系统数据流操作。
扩展:TBufferedTransport(提供读写buffer缓冲)、TFramedTransport(提供帧大小头信息,用以批数据传输或非阻塞操作)、TMemoryBuffer(直接从堆栈中读写)
三、Protocol
数据结构和数据传输解耦。
1、接口,双向消息序列化反序列化,基本方法如下:
writeMessageBegin(name, type, seq)
writeMessageEnd()
writeStructBegin(name)
writeStructEnd()
writeFieldBegin(name, type, id)
writeFieldEnd()
writeFieldStop()
writeMapBegin(ktype, vtype, size)
writeMapEnd()
writeListBegin(etype, size)
writeListEnd()
writeSetBegin(etype, size)
writeSetEnd()
writeBool(bool)
writeByte(byte)
writeI16(i16)
writeI32(i32)
writeI64(i64)
writeDouble(double)
writeString(string)
方法操作消息内容:
name, type, seq = readMessageBegin() readMessageEnd()
name = readStructBegin() readStructEnd()
name, type, id = readFieldBegin() readFieldEnd()
k, v, size = readMapBegin() readMapEnd()
etype, size = readListBegin() readListEnd()
etype, size = readSetBegin() readSetEnd()
bool = readBool()
byte = readByte()
i16 = readI16()
i32 = readI32()
i64 = readI64()
double = readDouble()
string = readString()
2、...
四、RPC实现
1、TProcessor
基本定义:
interface TProcessor {
bool process(TProtocol in, TProtocol out) throws TException
}
任何复杂的系统简而来说节课分为两个端客户端、服务端,用于处理输入输出。
process() 用于处理方法调用逻辑。
2、TServer
基本处理逻辑:
->使用TServerTransport接受TTransport
->使用TTransportFactory转换TTransport为实际应用的类型(通常应用TBufferedTransportFactory)
->使用TProtocolFactory为TTransport创建输入输出
->调用TProcessor process()逻辑
server处理连接;processor处理RPC逻辑。
不同实现:
TSimpleServer:单处理线程
TThreadedServer:每个连接一个处理线程
TThreadPoolServer:线程池处理
五、实现细节
。。。
Apache Thrift 白皮书的更多相关文章
- Apache thrift RPC 双向通信
在上一篇介绍Apache thrift 安装和使用,写了一个简单的demo,讲解thrift服务的发布和客户端调用,但只是单向的客户端发送消息,服务端接收消息.而客户端却得不到服务器的响应. 在不涉及 ...
- Apache Thrift 跨语言服务开发框架
Apache Thrift 是一种支持多种编程语言的远程服务调用框架,由 Facebook 于 2007 年开发,并于 2008 年进入 Apache 开源项目管理.Apache Thrift 通过 ...
- Apache Thrift 环境配置
在 Ubuntu 14.04 下Apache Thrift 的安装方法: 1安装依赖包 sudo apt-get install libboost-dev libboost-test-dev libb ...
- Apache Thrift 服务开发框架学习记录
Apache Thrift 是 Facebook 实现的一种高效的.支持多种编程语言的远程服务调用的框架. 前言: 目前流行的服务调用方式有很多种,例如基于 SOAP 消息格式的 Web Servic ...
- Apache Thrift
Baidu Thrift Google Thrift Apache Thrift - 可伸缩的跨语言服务开发框架
- Apache Thrift - 可伸缩的跨语言服务开发框架
To put it simply, Apache Thrift is a binary communication protocol 原文地址:http://www.ibm.com/developer ...
- Apache Thrift学习之二(基础及原理)
Apache Thrift 是 Facebook 实现的一种高效的.支持多种编程语言的远程服务调用的框架.本文将从 Java 开发人员角度详细介绍 Apache Thrift 的架构.开发和部署,并且 ...
- Apache Thrift学习之一(入门及Java实例演示)
目录: 概述 下载配置 基本概念 数据类型 服务端编码基本步骤 客户端编码基本步骤 数据传输协议 实例演示(java) thrift生成代码 实现接口Iface TSimpleServer服务模型 T ...
- Apache Thrift入门(安装、测试与java程序编写)
安装Apache Thrift ubuntu linux运行: #!/bin/bash #下载 wget http://mirrors.cnnic.cn/apache/thrift/0.9.1/thr ...
- Apache Thrift的简单使用
Apache Thrift的简单使用 ---------------------- 1. 简介 Thrift是Facebook的一个开源项目,主要是一个跨语言的服务开发框架.它有一个代码生成器来对它所 ...
随机推荐
- .Net Core Entity Framework Core 的基础封装
上篇讲到 c# Unit of Work 知识分享时,对于创建DBContext 的封装没有讲到,这次分享跟大家 public interface IDbContextFactory { DbCon ...
- 【Android 逆向】frida 检测绕过
1. aaa.apk 安装到手机,是一个叫玩吧的应用 ./hooker ...... 23248 浏 览 器 com.browser2345_oem 32541 玩吧 com.wodi.who 244 ...
- Vue源码学习(十一):计算属性computed初步学习
好家伙, 1.Computed实现原理 if (opts.computed) { initComputed(vm,opts.computed); } function initComputed(v ...
- 【Azure APIM】APIM Self-Hosted网关中,添加网关日志以记录请求头信息(Request Header / Response Header)
问题描述 在APIM Gateway 日志中, 对于发送到APIM Host的请求,只记录了一些常规的URL, Status, Time, IP等信息.关于请求Header, Body中的信息,因为隐 ...
- Nebula Graph 源码解读系列 | Vol.01 Nebula Graph Overview
上篇序言中我们讲述了源码解读系列的由来,在 Nebula Graph Overview 篇中我们将带你了解下 Nebula Graph 的架构以及代码仓分布.代码结构和模块规划. 1. 架构 Nebu ...
- 详解 nebula 2.0 性能测试和 nebula-importer 数据导入调优
这是由社区用户--繁凡撰写的一篇他的实践分享,主要讲解如何进行 Nebula 性能测试以及数据导入部分的性能调优.下文中出现的"我"代指用户繁凡. 0. 概要 之前在做 Nebul ...
- 3D模型+BI分析,打造全新的交互式3D可视化大屏开发方案
背景介绍 在数字经济建设和数字化转型的浪潮中,数据可视化大屏已成为各行各业的必备工具.然而,传统的数据大屏往往以图表和指标为主,无法真实地反映复杂的物理世界和数据关系.为了解决这个问题,3D模型可视化 ...
- tomcat 安装笔记 20230901
war位置 /usr/local/tomcat8_1/webapps/ tomcat位置 71.170 /usr/local/tomcat8_1/ 给了点工具包 位置 /usr/local/tool/ ...
- linux 服务器 执行命令挂起 nohup 改用 pm2
nohup http-server -p 80 & nohup完要 exit 退出,不能直接关! nohup完要 exit 退出,不能直接关! nohup完要 exit 退出,不能直接关! 重 ...
- Dreamweaver基础教程:学习JavaScript
目录 简介 用法 输出 语法 字面量 变量 操作符 语句 关键字 注释 数据类型 函数 函数表达式 Function() 构造函数 自调用函数 箭头函数 arguments 对象 使用构造函数调用函数 ...