HSF

HSF是一个分布式RPC框架,联通各种不同的分布式系统,以服务的方式调用。其核心有服务注册中心(ConfigServer)、RPC框架和服务治理(包括服务寻址、路由、限流等)。图6-5所示是HSF微服务框架,以及各个核心模块之间的交互流程。

微服务主流框架概览_微服务

HSF底层的通信基于Netty设计实现高性能的服务器之间远程调用,支持多种序列化方式(java、hessian1、hessian2、kryo、fastjson和customized等)和多种RPC协议(HSF、Dubbo等),高性能得益于快速高效的二进制协议,包括二进制序列化和TCP。

HSF对开发最大的价值是透明地将本地调用转换为远程调用,而无须改动业务代码,客户端通过代理模式,支持多种调用方式,分别是同步调用、future并行调用、callback异步回调、泛化调用,以及HTTP调用。

HSF服务治理包括服务发布和寻址,以及通过各种规则来实现诸如限流、白名单、授权、路由、同机房优先、单元化、动态分组、权重路由、降级等功能,配置和规则放在Diamond集中管理,有专门的ops页面进行维护,所有客户端和服务器端都会订阅这些配置和规则。

Dubbo

Dubbo是一款高性能、轻量级的开源Java RPC框架。它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。

Dubbo最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦(或者最大限度地松耦合)。从服务模型的角度来看,Dubbo采用的是一种非常简单的模型,要么是提供方提供服务,要么是消费方消费服务。

微服务主流框架概览_微服务_02

Dubbo采用的是JavaDevelopment Kit(JDK)标准的串行外设接口(Serial Peripheral Interface,SPI)扩展机制,微核心+插件式,平等对待所有的第三方插件,扩展性极佳。

Spring Cloud

Spring Cloud为最常见的分布式系统模式提供了简单易用的编程模型,帮助开发人员构建弹性、可靠和协调的应用程序。

Spring Cloud是一系列框架的有序集合,它利用 Spring Boot 的开发便利性巧妙地简化了分布式系统基础设施的开发,比如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控、链路追踪等。

Spring Cloud采用的是基于HTTP的REST方式。RPC一般面向接口引用来调用远端服务,对开发人员更加友好,且RPC主要是基于TCP/IP的,调用参数采用二进制进行序列化,网络传输更加精简高效;RPC的缺点是调用双方存在技术栈的强绑定。REST比RPC更灵活,天然具有跨语言的优势,服务提供方和调用方的依赖只依靠一纸契约,不存在代码级的强依赖,这在强调快速演进的微服务环境下,显得更加合适。

微服务主流框架概览_微服务_03

gRPC

gRPC是一个基于HTTP/2通信协议和Protobuf序列化的RPC实现,其前身是谷歌内部大量使用的Stubby服务间通信产品。gRPC已被CNCF所收录,作为云原生架构的一个进程之间服务调用参考。

在gRPC中,客户端应用可以像调用本地对象的方法一样直接调用部署在其他机器上的服务器端应用的方法。gRPC降低了构建分布式应用和服务的难度。和其他RPC系统一样,gRPC的核心也是服务定义,定义可以被远程调用的方法的入参和返回值。gRPC客户端和服务器端既可以在多种不同的环境下运行并相互通信,也可以使用gRPC支持的语言实现。

微服务主流框架概览_微服务_04

gRPC并不算是一个完整的微服务框架,而只是一个轻量级远程服务调用技术。通常我们不会单独使用gRPC,而是将gRPC作为一个组件进行使用。这是因为生产环境中在面对大并发的情况时,需要使用分布式系统来处理,而gRPC并没有提供分布式系统相关的一些必要组件。

Service mesh

service mesh是一种非侵入式架构,用于处理服务到服务通信的专用基础设施层。它负责通过复杂的服务拓扑来可靠地传递请求。

service mesh帮助应用程序在海量服务、复杂的架构和网络中建立稳定的通信机制。业务所有的流量都转发到service mesh的代理服务中,支撑应用之间透明的网络调用,可以确保应用的调用请求在复杂的微服务应用拓扑中可靠地穿梭。

service mesh通常由一系列轻量级的网络代理组成,这通常被形象地称为边车(sidecar)模式,与应用程序部署在一起,但应用程序不需要知道它们的存在。以旁路的方式为应用系统提供服务发现、路由、负载均衡、健康检查和可观察性来帮助管理流量。

service mesh承担了微服务框架的所有功能,包括服务注册发现、负载均衡、熔断限流、认证鉴权、缓存加速、运行监控等。可以说,service mesh是云原生下的微服务治理方案。微服务架构强调去中心化、独立自治、跨语言,service mesh通过独立进程的方式进行了隔离,可以低成本实现微服务框架这些特性。

当下主流的service mesh框架有:Linkerd、Envoy、Istio、SOFAMesh。有兴趣的读者可以去各个官网上查看相关信息。