thrift源码分析-架构设计

前言

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

架构图

模块划分

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

  • 代码生成器

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

  • 低级传输层

靠近网络层、做为rpc框架接收报文的入口,提供各类底层实现如socket建立、读写、接收链接等。架构

  • 复写传输层

基于低级传输层,实现各类复写传输层包括http、framed、buffered、压缩传输层等,复写传输层能够被协议层直接使用,用户也能够经过重写低级传输层和复写传输层实现本身的传输层。框架

  • 协议层

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

  • 处理层

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

  • 服务层

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

总结

以上为thrift的总体模块划分,在接下来的文章中会针对每个模块,作单独的解析。oop

参考资料

thrift官网cdn

thrift白皮书

相关文章
相关标签/搜索