主流RPC框架

介绍目前在互联网公司比较流行的开源的RPC框架。

RPC框架比较

  语言 协议 ​服务治理 ​社区 机构
Hessian 多语言 hessian 不活跃 Caucho
Thrift 多语言 thrift 活跃 Apache
Finagle Java/Scala 多协议 支持 活跃 Twitter
TChannel 多语言 thrift 支持 活跃 Uber
Dubbo Java 支持拓展 支持 停滞 阿里

详细介绍

Hassian

Hassian被广泛用做二进制编码协议,但本身也是一个Web Service框架对RPC调用提供支持,功能简单,使用起来也方便。

有些像《RPC》介绍的SimpleRPCFramework,只是把编码协议从Java Serialization替换为hassian。

Thrift

Thrift是一个跨语言的RPC框架,自带的代码生成引擎大幅提高了开发效率,从而使它如此流行。

最初由Facebook团队设计开发,现在已贡献给Apache。

Thrift基于接口描述语言定义的Model(契约),Thrift Compiler进行解析并自动生成目标语言Client和Server端的代码框架,直接基于此框架开发服务或者与现有系统集成都可以较方便实现。

基于Thrift开发远程服务调用,后续Model的改动会导致上下游产生较大升级成本,因此服务双方应先仔细定义Model。

公司内部所有Model应由专门的系统进行统一版本管理、编译、发布。

Finagle

Finagle是一个专门为Java/Scala设计的、成熟的RPC框架。

简单、高效、支持基本服务治理功能,所有服务治理功能均在Client端集成:服务发现、负载均衡、容错、日志收集等。

使用Scala开发,国内没有听说过有团队使用此框架。

TChannel

TChannel是一个支持多语言的RPC框架,主要编码协议为thrift,同时又参考Finagle基于Dapper设计自己的集群监控实现。

服务治理与Finagle不同,由类似系统总线的独立的路由系统进行服务治理,本身这种系统结构存在单点故障风险,已经被多数公司放弃。但优点显而易见,功能集中在一个系统中,对于系统维护和升级要方便得多,极大降低降低各语言终端的开发成本和框架升级引入的潜在风险。

Dubbo

Dubbo是阿里巴巴开源的专门为Java设计的、成熟的RPC框架。

支持基本的服务治理,所有服务治理功能均在Client端集成:服务发现、负载均衡、容错、监控等。

采用微内核+插件体系,所有组件都可以遵循一定的规则进行替换,拥有较强的拓展性。

主流的搭配:

zookeeper作服务中心

thrift/dubbo作为编码协议

netty作为底层通信模块

Dubbo定义了自己的spring schema,与spring项目进行集成相当方便。

如果是Java系统推荐使用Dubbo,如果是多语言系统可以为Dubbo添加thrift原生协议支持(Dubbo本身不支持原生的thrift协议),通过thrift代码生成引擎支持多语言调用。

FW:主流RPC框架的更多相关文章

  1. 主流RPC框架详解,以及与SOA、REST的区别

    什么是RPC RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议. 简言之,RPC使 ...

  2. 主流的RPC框架有哪些

    RPC是远程过程调用的简称,广泛应用在大规模分布式应用中,作用是有助于系统的垂直拆分,使系统更易拓展.Java中的RPC框架比较多,各有特色,广泛使用的有RMI.Hessian.Dubbo等.RPC还 ...

  3. rpc框架之 thrift 学习 1 - 安装 及 hello world

    thrift是一个facebook开源的高效RPC框架,其主要特点是跨语言及二进制高效传输(当然,除了二进制,也支持json等常用序列化机制),官网地址:http://thrift.apache.or ...

  4. 简易RPC框架-客户端限流配置

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  5. 序列化战争:主流序列化框架Benchmark

    序列化战争:主流序列化框架Benchmark GitHub上有这样一个关于序列化的Benchmark,被好多文章引用.但这个项目考虑到完整性,代码有些复杂.为了个人学习,自己实现了个简单的Benchm ...

  6. 服务化实战之 dubbo、dubbox、motan、thrift、grpc等RPC框架比较及选型

    转自: http://blog.csdn.net/liubenlong007/article/details/54692241 概述 前段时间项目要做服务化,所以我比较了现在流行的几大RPC框架的优缺 ...

  7. RPC 框架 应用

    RPC RPC(Remote Procedure Call)服务,也即远程过程调用,在互联网企业技术架构中占据了举足轻重的地位,尤其在当下微服务化逐步成为大中型分布式系统架构的主流背景下,RPC 更扮 ...

  8. RPC框架基础概念理解以及使用初体验

    RPC:Remote Procedure Call(远程服务调用) RPC是做什么的 通过RPC框架机器A某个进程可以通过网络调用机器B上的进程方法,就像在本地上调用一样. RPC可以基于HTTP或者 ...

  9. dubbo、dubbox、motan、thrift、grpc等RPC框架比较及选型

    概述 前段时间项目要做服务化,所以我比较了现在流行的几大RPC框架的优缺点以及使用场景,最终结合本身项目的实际情况选择了使用dubbox作为rpc基础服务框架.下面就简单介绍一下RPC框架技术选型的过 ...

随机推荐

  1. 对称加密算法-DES以及DESede算法

    一.简述 对称加密算法就是能将数据加解密.加密的时候用密钥对数据进行加密,解密的时候使用同样的密钥对数据进行解密. DES是美国国家标准研究所提出的算法.因为加解密的数据安全性和密钥长度成正比.des ...

  2. php的ord函数——解决中文字符截断问题

    php的ord函数——解决中文字符截断问题 分类: PHP2014-11-26 12:11 1033人阅读 评论(0) 收藏 举报 utf8字符截取 函数是这样定义的: int ord ( strin ...

  3. Mac环境配置好ant后提示Permission denied

    1.ant环境变量配置如下 打开终端,输入vi ~/.bash_profile export ANT_HOME=/Users/administrator/Documents/software/apac ...

  4. JAVA-Word转PDF各种版本实现方式

    当下做一个项目,就是各种操作office,客户的需求总是各种不按常理,来需求就得搞啊.对JAVA操作office这方面真是头大,弟弟是真滴不懂不会啊.无奈只好试啊试的.网上一大堆好使的,一大堆不好使的 ...

  5. 翻译:Laravel-4-Generators 使用自己定义代码生成工具高速进行Laravel开发

    使用自己定义代码生成工具高速进行Laravel开发 这个Laravle包提供了一种代码生成器,使得你能够加速你的开发进程.这些生成器包含: generate:model – 模型生成器 generat ...

  6. windbg的使用

      1. set 1.1. 设置Symbol file path file->symbol file path, 如: D:\***\TestProject\pdb   1.2 设置source ...

  7. 代码生成利器:IDEA 强大的 Live Templates

    Java 开发过程经常需要编写有固定格式的代码,例如说声明一个私有变量, logger 或者 bean 等等.对于这种小范围的代码生成,我们可以利用 IDEA 提供的 Live Templates 功 ...

  8. bootstrap基础学习八篇

    bootstrap辅助类 a.对于文本颜色 以下不同的类展示了不同的文本颜色.如果文本是个链接鼠标移动到文本上会变暗: 类 描述 .text-muted "text-muted" ...

  9. error: Please reinstall the libcurl distribution - easy.h should be in <curl-dir>/include/curl/

    运行php-5.3.10 --enable-mbstring --enable-ftp --enable-gd-native-ttf --with-openssl --enable-pcntl --e ...

  10. AWS系列-创建AMI

    AMI创建 在XEN中pv是半虚拟化,hvm是全虚拟化,pv只能用于linux内核的系统,效率更高,hvm可以虚拟所有常见操作系统(可以使用 windows),理论效率比pv略低,另外,hvm需要cp ...