前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Service Mesh - 理论篇

Service Mesh - 理论篇

作者头像
端碗吹水
发布2020-12-23 14:40:49
6430
发布2020-12-23 14:40:49
举报
文章被收录于专栏:程序猿的大杂烩

Service Mesh的起源:为什么会出现Service Mesh技术?

微服务架构的特性

特点 1:围绕业务构建团队

Service Mesh - 理论篇
Service Mesh - 理论篇

特点 2:去中心化的数据管理

Service Mesh - 理论篇
Service Mesh - 理论篇

微服务架构面临什么样的问题?

微服务架构的优势

  • 团队层面:内聚,独立开发业务,没有依赖
  • 产品层面:服务彼此独立,独立部署,没有依赖
  • 微服务是软件架构的银弹吗?而银弹理论已经说明了没有任何一种技术和管理上的进步,可以极大的提升生产效率

服务之间的网络通信是微服务架构的一大痛点,当微服务越来越多时,整体的调用链路就呈现一个复杂的图状:

Service Mesh - 理论篇
Service Mesh - 理论篇

为什么网络通信是微服务架构的痛点?分布式计算的 8 个谬论(Fallacies of Distributed Computing Explained):

  • 网络是可靠的
  • 网络延迟是 0
  • 带宽是无限的
  • 网络是安全的
  • 网络拓扑从不改变
  • 只有一个管理员
  • 传输成本是 0
  • 网络是同构的

如何管理和控制服务间的通信?

  • 服务注册/发现
  • 路由,流量转移
  • 弹性能力(熔断、超时、重试)
  • 安全
  • 可观测性

Service Mesh的发展:Service Mesh技术是如何演进的?

第一阶段:控制逻辑和业务逻辑耦合

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 网络调用、熔断、服务发现等控制逻辑与业务逻辑交杂耦合在一起

第二阶段:公共库

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 这个公共库可以是第三方的,例如Spring Cloud体系中的一些相关框架
  • 在这个阶段达到了控制逻辑和业务逻辑解耦、消除重复
  • 但需要花人力和时间成本去学习这个库以及维护它,并且通常是语言绑定,且仍有侵入

第三阶段:代理

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 公共库不再和现在的业务逻辑部署在一起,而是单独抽出一个代理模块,由该模块去包含相应的控制逻辑
  • 功能简陋,但思路正确

第四阶段:边车模式(Sidecar)

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 在应用旁边部署一个Sidecar,由Sidecar去处理所有的网络请求以及相应的控制逻辑,然后再把请求转发给应用

第五阶段:Service Mesh 的出现

Service Mesh - 理论篇
Service Mesh - 理论篇

微服务通信的济世良方:什么是Service Mesh?它能帮你做什么?

Service Mesh 的定义

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 所谓 Service Mesh 就是一个用来进行请求转发的基础设施层,它通常是以Sidecar的形式部署,并且对应用透明

Service Mesh 的产品形态

Service Mesh - 理论篇
Service Mesh - 理论篇
  • Service Mesh 是 Sidecar 的网络拓扑模式。整体上分为数据平面和控制平面

Service Mesh 的主要功能

Service Mesh - 理论篇
Service Mesh - 理论篇

Service Mesh 和 Kubernetes 的关系

Service Mesh - 理论篇
Service Mesh - 理论篇

Service Mesh 和 API 网关的异同点

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 功能有重叠,但角色不同
  • Service Mesh 在应用内,API 网关在应用之上(边界)

Service Mesh 技术标准

Service Mesh - 理论篇
Service Mesh - 理论篇

列王的纷争:市面上有哪些主流的Service Mesh产品?

Service Mesh - 理论篇
Service Mesh - 理论篇

Linkerd

  • 第一个 Service Mesh 产品
  • 2016 年底在 GitHub 上发布 0.x
  • 2017 年加入 CNCF,4 月发布 1.0 版本
  • Conduit – Linkerd2.0:支持 Kubernetes,轻量化
  • Linkerd 的败局?

envoy

  • 2016 年 9 月发布
  • 定位于 Sidecar 代理
  • 第 3 个从 CNCF 毕业的产品
  • 稳定可靠,性能出众
  • Istio 的默认数据平面
  • xDS 协议成为数据平面的事实标准

Istio

  • 2017 年 5 月发布 0.1
  • 光环加身:Google,IBM,Lyft 背书
  • 第二代 Service Mesh,增加了控制平面,奠定目前 Service Mesh 的产品形态
  • 收编 Envoy,直接拥有高水准的数据平面
  • 受到社区强烈追捧

AWS App Mesh

Service Mesh - 理论篇
Service Mesh - 理论篇
  • 2018 年 re:Invent 公布
  • 2019 年 4 月 GA 发布
  • 支持自家的多种计算资源的部署
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/12/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Service Mesh的起源:为什么会出现Service Mesh技术?
    • 微服务架构的特性
      • 微服务架构面临什么样的问题?
      • Service Mesh的发展:Service Mesh技术是如何演进的?
        • 第一阶段:控制逻辑和业务逻辑耦合
          • 第二阶段:公共库
            • 第三阶段:代理
              • 第四阶段:边车模式(Sidecar)
                • 第五阶段:Service Mesh 的出现
                • 微服务通信的济世良方:什么是Service Mesh?它能帮你做什么?
                  • Service Mesh 的定义
                    • Service Mesh 的产品形态
                      • Service Mesh 的主要功能
                        • Service Mesh 和 Kubernetes 的关系
                          • Service Mesh 和 API 网关的异同点
                            • Service Mesh 技术标准
                            • 列王的纷争:市面上有哪些主流的Service Mesh产品?
                            相关产品与服务
                            容器服务
                            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                            领券
                            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档