前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mesh: SideCar 是什么?

Mesh: SideCar 是什么?

作者头像
MickyInvQ
发布2020-09-27 15:21:31
1.9K0
发布2020-09-27 15:21:31
举报
文章被收录于专栏:InvQ的专栏InvQ的专栏
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

嗯,,sidecar就是上面这种。。

mesh : 微服务传统形态 和 sidecar形态

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

特征:

传统形态下,SDK代表着一个特定语言的库、工具包等,由应用程序和微服务框架(比如说dubbo)共处一个进程中,在发布升级中共享生命周期。

serviceMesh下,推荐的是右边的sidecar方案,sidecar方案下没有引入新的功能,调用的拓扑也没有改变,只是改变了原有功能的位置,以独立的应用来存在。大家可以暂时以nginx来理解其网络代理能力也可以。

在这里插入图片描述
在这里插入图片描述
  • 在ServiceMesh架构中,给每一个微服务实例部署一个SidecarProxy。该SidecarProxy负责接管对应服务的入流量和出流量,并将微服务架构中的服务订阅、服务发现、熔断、限流、降级、分布式跟踪等功能从服务中抽离到该Proxy中。
  • Sidecar以一个独立的进程启动,可以每台宿主机共用同一个Sidecar进程,也可以每个应用独占一个Sidecar进程。所有的服务治理功 能,都由Sidecar接管,应用的对外访问仅需要访问Sidecar即可。当该Sidecar在微服务中大量部署时,这些Sidecar节点自然就形成了一个服务网格。

微服务框架的痛点和改进

  • 对于基础架构框架开发者来说存在痛点:面向开发者的模式:新加了功能需要使用框架的应用开发人员配合升级版本,比如要升级maven中的依赖版本号,重新打包发布应用程序,时间上受制于相应的业务应用。业务开发人员相对来说只考虑自身业务稳定等因素,对基础框架的升级具有天然的抗拒心理。
  • 使用SideCar模式带来的改进:这个模式的精髓在于实现了数据面(业务逻辑)和控制面的解耦。带来了下面的两个优点: 1、面向运维:解耦了调用业务方和微服务,让它们的具备不同的发布升级的生命周期 2、SideCar作为一个代理,可以完成更多的功能,比如跨语言、限流、负载均衡、灰度、熔断等都可以放到SideCar代理里

缺点: 1、从调用方到服务方增加了两次调用,有性能上的损失。(实际上的设计针对这个做优化,物理机上所有应用跟SideCar之间虽然是跨进程,处于不同的JVM应用中,但是它们处于同一台物理机中,故它们之间的调用可以走内核态方式,整体性能的损失可以在1%以内,平均延迟1.5毫秒左右),理论上多一跳的平均性能损耗在1.5毫秒左右; 2、调用复杂度增加,问题排查难度加大

总结: 对于大规模部署微服务,内部服务异构程度高的场景,使用ServiceMesh方案是一个不错的选择。ServiceMesh实现了业务逻辑和控制的解耦,但是也带来了额外的开销,由于网络中多了一次调用,增加了性能的损耗和访问的延迟。同时,由于每个服务(一般每一台物理机) 都需要部署Sidecar,这也会使本来就具有一定复杂度的分布式系统变得更加复杂。尤其是在实施初期,对ServiceMesh的管理和运维会是一个比较棘手的问题。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-08-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • mesh : 微服务传统形态 和 sidecar形态
    • 微服务框架的痛点和改进
    相关产品与服务
    负载均衡
    负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档