ServiceMesh(服务网格服务网格)入门入门
现在最火的后端架构无疑是微服务了,微服务将之前的单体应用拆分成了许多独立的服务应用,每个微服务都是独立的。
微服务基本组件包括服务注册和发现、服务通信和治理、故障熔断恢复、配置、安全、监控等等,这些微服务组件和功能在业
界已经深入人心,在各大互联网公司开花结果,业界知名开源的微服务框架有 Netflix OSS、Spring Cloud 及其国内的阿里
Dubbo 等等,各种框架百花齐放。
微服务好处自然很多,但是随着应用的越来越大,微服务暴露出来的问题也就随之而来了,微服务越来越多,管理越来越麻
烦。特别是要你部署一套新环境的时候,随之而来的服务发现、负载均衡、Trace跟踪、流量管理、安全认证等等问题。
当然随着微服务的不断发展,微服务的生态的不断完善,新的微服务框架 Service Mesh 的出现就是为了解决这一系列问题。
什么是 Service Mesh
Service Mesh 是一个非常新的名词,最早是 2016 年由开发 Linkerd 的 Buoyant 公司提出的,伴随着 Linkerd 的传
入,Service Mesh 的概念也慢慢进入国内技术社区。
Service Mesh 是一个基础设施层,其独立运行在应用服务之外,提供应用服务之间安全、可靠、高效的通信,并为服务通信
实现了微服务运行所需的基本组件功能,包括服务注册发现、负载均衡、故障恢复、监控、权限控制等等。Service Mesh 的
中文译为 “服务网格”。
Willian Morgan(Linker 的 CEO)给出的 Service Mesh 定义:
服务网格是一个用于处理服务间通信的基础设施层,它负责为构建复杂的云原生应用传递可靠的网络请求。在实践中,服务网
格通常实现为一组和应用程序部署在一起的轻量级的网络代理,但对应用程序来说是透明的。
一个典型的 Service Mesh 部署网络结构图
其中绿色方块为应用服务,蓝色方块为 Sidecar Proxy,应用服务之间通过 Sidecar Proxy 进行通信,整个服务通信形成图中
的蓝色网络连线,图中所有蓝色部分就形成了 Service Mesh。
Service Mesh 的特点
Service Mesh 有如下几个特点:
应用程序间通讯的中间层
轻量级网络代理