微服务主流框架和基础设施介绍
🕗 发布于 2025-01-15 11:28 微服务 服务网格
概述
微服务架构的落地需要解决服务治理问题,而服务治理依赖良好的底层方案。当前,微服务的底层方案总的来说可以分为两 种:微服务SDK
(微服务框架)和服务网格。
微服务框架运行原理:
应用程序通过接入
SDK
来实现服务治理,
SDK
运行在应用程序的上下文(相同进程),构建后成为应用程序的一部分。
服务网格运行原理:
通过
Sidecar
模式,用单独的代理进程接管应用程序的网络流量,从而实现服务治理,借助代理进程,可以实现服务的流量控制
(访问权限控制、限流、熔断等等)、服务发现、负载均衡等等服务治理相关功能。
微服务框架
Spring Boot + Spring Cloud
SpringBoot
是最流行的
Java
应用框架,而
SpringCloud
是面向微服务治理的不同需求的一整套框架的集合,或者说框架的规范 (而且是弱规范,之所以说只能称为弱规范,因为同一个问题,SpringCloud
中有不同的框架来解决,而且从一种切换到另一 种,需要修改代码,比如说Hytrix
和
Sentinel
,流行的全家桶也从
SpringCloud Netflix
过度到了
SpringCloud Alibaba
等等)。可以认
为
SpringCloud
是
SpringBoot
的扩展,铁打的
SpringBoot
,流水的
SpringCloud
扩展。
GoMicro
go micro
是一个基于可插拔式
RPC
的底层库,提供用
go
语言写微服务的各种构造块。
go micro
使用
consul
实现服务发现,通信基于 http,编码则使用
proto-rpc
,
json-rpc
,并且提供发布
/
订阅模式。
go micro
致力于解决建立可伸缩系统的关键性问题,它把微服务架构模式拆解并转换成了一组工具集,能够解决分布式系统中 的复杂性问题,并且向程序员提供易于理解的简单抽象。
Axon
Axon
是一款面向
DDD
和事件驱动架构的服务框架。
Axon
包含一套编程模型以及支撑这套模型的基础设施,
Axon
包括
Axon
框架 和Axon Server
,其中
Axon
框架提供编程模型而
Axon Server
提供基础设施部分。
Axon
是开源的。
服务网格
Istio
Istio
是服务网格技术的主流实现,它为
Kubernetes
提供了一组扩展,借助其中的
Envoy
服务代理能够无侵入(弱侵入)地提供服 务的流量管理、遥测技术、安全管控等等重要的服务治理能力。
Istio
服务网格由控制平面和数据平面构成。控制平面的核心组件是
Pilot
和
Mixer
,数据平面的核心组件是
Envoy
。此外,为了实现 遥测,一般来说,我们还会用Prometheus
来采集和存储监控数据,用
zipkin
和
opentracing
来采集调用链跟踪数据,用
kiali
来进行监
控指标的可视化。
原文地址:https://blog.csdn.net/qq_30621637/article/details/145136805
免责声明:本站文章内容转载自网络资源,如侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!