thrift源码分析-架构设计

栏目: 后端 · 发布时间: 7年前

内容简介:thrift是一个轻量级、跨语言、提供代码生成机制的rpc框架,提供了数据传输、序列化、应用层处理的清晰抽象。thrift自身已经非常成熟,支持超过二十种语言,一些基础项目如hadoop也将thrift集成到自己的多语言sdk内,如果你的公司正在进行多语言微服务技术选型,thrift会是一个不错的选择。本系列文章会从整体架构、模块源码层面进行剖析,力求呈现出一个更具体的thrift框架。抛开语言层面,thrift可分为以下几个组件,其中传输层被细分为低级传输层和复写传输层。根据thrift idl文件生成

thrift是一个轻量级、跨语言、提供代码生成机制的rpc框架,提供了数据传输、序列化、应用层处理的清晰抽象。thrift自身已经非常成熟,支持超过二十种语言,一些基础项目如hadoop也将thrift集成到自己的多语言sdk内,如果你的公司正在进行多语言微服务技术选型,thrift会是一个不错的选择。本系列文章会从整体架构、模块源码层面进行剖析,力求呈现出一个更具体的thrift框架。

架构图

thrift源码分析-架构设计

模块划分

抛开语言层面,thrift可分为以下几个组件,其中传输层被细分为低级传输层和复写传输层。

  • 代码生成器

根据thrift idl文件生成各个语言代码,位于compiler目录内。

  • 低级传输层

靠近网络层、作为rpc框架接收报文的入口,提供各种底层实现如socket创建、读写、接收连接等。

  • 复写传输层

基于低级传输层,实现各种复写传输层包括http、framed、buffered、压缩传输层等,复写传输层可以被协议层直接使用,用户也可以通过重写低级传输层和复写传输层实现自己的传输层。

  • 协议层

协议层主要负责解析请求、应答报文为具体的结构体、类实例,供处理层直接使用,目前的协议包括Binary(最为常用)、json、多路混合协议等。

  • 处理层

由代码生成器生成,根据获取到的具体信息如method name,进行具体的接口处理,处理层构造函数的入口包含一个handler,handler由业务方进行具体的实现,然后在处理层内被调用,并应答处理结果。

  • 服务层

融合低级传输层、复写传输层、协议层、处理层,自身包含各种不同类型的服务模型,如非阻塞单进程服务、one request per fork、one request per thread、thread pool等模型。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

浪潮之巅(上册)

浪潮之巅(上册)

吴军 / 人民邮电出版社 / 2013-5-1 / 35.00元

《浪潮之巅(第2版)(上册)》不是一本科技产业发展历史集,而是在这个数字时代,一本IT人非读不可,而非IT人也应该阅读的作品。一个企业的发展与崛起,绝非只是空有领导强人即可达成。任何的决策、同期的商业环境,都在都影响着企业的兴衰。《浪潮之巅》不只是一本历史书,除了讲述科技顶尖企业的发展规律,对于华尔街如何左右科技公司,以及金融风暴对科技产业的冲击,也多有着墨。此外,《浪潮之巅》也着力讲述很多尚在普......一起来看看 《浪潮之巅(上册)》 这本书的介绍吧!

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具