Service Mesh

Stella981
• 阅读 538

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

微服务架构的特性

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

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

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

微服务架构的优势

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

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

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

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

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

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

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

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

Service Mesh

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

第二阶段:公共库

Service Mesh

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

第三阶段:代理

Service Mesh

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

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

Service Mesh

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

第五阶段:Service Mesh 的出现

Service Mesh


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

Service Mesh 的定义

Service Mesh

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

Service Mesh 的产品形态

Service Mesh

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

Service Mesh 的主要功能

Service Mesh

Service Mesh 和 Kubernetes 的关系

Service Mesh

Service Mesh 和 API 网关的异同点

Service Mesh

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

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

  • 2018 年 re:Invent 公布
  • 2019 年 4 月 GA 发布
  • 支持自家的多种计算资源的部署

国内发展情况

  • 蚂蚁金服:SOFA Mesh,MOSN 数据平面
  • 几大云厂商(腾讯、阿里、百度)
  • 华为、微博
  • 其他
点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
MSTP+VRRP+OSPF+双出口
拓扑图!MSTPVRRPOSPF双出口(https://s4.51cto.com/images/blog/202012/14/3e101c381bc712f9915994275649ac00.png?xossprocessimage/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFF
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这