返回顶部
首页 > 资讯 > 前端开发 > node.js >ServiceMesh的关键之如何理解边车模式
  • 247
分享到

ServiceMesh的关键之如何理解边车模式

2024-04-02 19:04:59 247人浏览 薄情痞子
摘要

本篇内容主要讲解“ServiceMesh的关键之如何理解边车模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ServiceMesh的关键之如何理解边车模式”吧

本篇内容主要讲解“ServiceMesh的关键之如何理解边车模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ServiceMesh的关键之如何理解边车模式”吧!

一步步升级

注意:下面都是边车模式,只不过有的边车实在是简陋。

<1>

大家都知道,微服务是复杂的,引入了一系列的问题,服务治理显得尤关重要。比如日志收集、服务监控、服务治理等。

ServiceMesh的关键之如何理解边车模式

比如上面这张图,我们在一个linux服务器上,部署了四个进程。其中,WEB服务是最主要的进程,其他进程只是作为一些附加功能部署上去的。

其实,这三个圆圈,就是边车的功能。只要把它给挂载上,上面的服务就拥有了这些功能。

但对于这三个组件的配置,是相当复杂的。我们需要很多重复的工作。

ServiceMesh的关键之如何理解边车模式

<2>

上面这张图,通过将Web应用与我们的辅助应用打包在一块,进一步增强了  不可变性。拥有了容器的加持,我们就能够靠约定来简化打包和发布操作。比如,上面的各个组件就可以通过localhost直接通信。

但可惜的是,我们的这些辅助程序,都是作为Docker容器里的进程去启动的,这种 富容器模式  有诸多缺陷,不符合不可变基础设施的理念,所以并不值得推荐。

<3>

k8s的Pod,在容器的基础上,进一步抽象。一个Pod中可以包含多个容器。如下图,基础服务和Web服务可以分别独自构建,最后以Pod作为载体,搭上便车就可以了。

ServiceMesh的关键之如何理解边车模式

为了更加显著的看到这个过程,下面这张图以日志收集为例,介绍了两个pod,相同日志收集docker容器的拓扑图。

ServiceMesh的关键之如何理解边车模式

从上面的演进过程我们可以看到。边车,就是辅助或者基础程序而已。但如何方便的管理这些附加的程序,我们有不同的组织方式。只有高度的抽象层次,才能进行方便的组装与设计。

<4>

到此为止,我们可以看一下ServiceMesh经典的两张图了。

我们把Web应用(业务服务),抽象成绿色的方块。然后把辅助组件(sidecar),抽象成蓝色方块。在一个相对简单的环境中,我们的部署方式如下所示。

ServiceMesh的关键之如何理解边车模式

由于辅助组件并不能单独存在,所以它们都依附在绿色的服务上面。

我们抽调服务集群的血肉(Web服务),只留下它的筋骨(sidecar),就可以获得下面这张图,这就是ServiceMesh。可以看到里面的连接线条是非常复杂的,人工不可能完成,只能依靠平台去管理。

ServiceMesh的关键之如何理解边车模式

任何东西只要一上规模了,就体现了它的复杂度。这还仅仅是只有36个服务节点的拓扑图。

不要小看这一个小小的蓝色方块。它不仅仅可以是一个辅助程序,而且可以成为基础设施。现在典型的service  mesh,分为`数据平面`和`控制平面`,大多数落地的企业使用proxy方式实现了数据平面,对控制平面的实现有限。

像比较流行的Istio,通过负载均衡、服务间的身份验证、监控等方法,它可以轻松地创建一个已经部署了服务的网络,而服务的代码只需很少更改甚至无需更改。通过在整个环境中部署一个特殊的  sidecar代理,为服务添加 Istio 的支持,而代理会拦截微服务之间的所有网络通信,然后使用其控制平面的功能来配置和管理 Istio。

我们看下它官方的功能描述:

  1. Httpgrpcwebsockettcp 流量自动负载均衡。

  2. 通过丰富的路由规则、重试、故障转移和故障注入对流量行为进行细粒度控制。

  3. 可插拔的策略层和配置 api,支持访问控制、速率限制和配额。

  4. 集群内(包括集群的入口和出口)所有流量的自动化度量、日志记录和追踪。

  5. 在具有强大的基于身份验证和授权的集群中实现安全的服务间通信。

可以说,ServiceMesh将业务属性剥离了出去,只剩下一张大网,涵盖了所有运维和基础服务的工作。

要用它,不能说是没有代价的。其中有两点比较重要:

网络包通过层层的代理和转发(Ambassador模式),效率会降低,排错会变困难。

需要按照这个网格的规范进行改造,也就是写一堆适配器(Adapter模式)。

SpringCloud的Sidecar

说到适配器,就不禁想起了SpringCloud的Sidecar。

Java里要说玩新概念,怎么能少的了spring家族?SprinGCloud同样有一个sidecar的组件,它的Maven坐标如下。

<dependency>             <groupId>org.springframework.cloud</groupId>             <artifactId>spring-cloud-netflix-sidecar</artifactId> </dependency>

它做的事情,更加像一个适配器。它能把一个普通的PHP或者nodejs服务,伪装成一个正常的SpringCloud服务。

通过简单的配置,我们就可以让一些其他语言开发的Web应用,加入到SpringCloud体系中来。

它的使用比较简单,在此不过多介绍。

到此,相信大家对“ServiceMesh的关键之如何理解边车模式”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: ServiceMesh的关键之如何理解边车模式

本文链接: https://lsjlt.com/news/84568.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • ServiceMesh的关键之如何理解边车模式
    本篇内容主要讲解“ServiceMesh的关键之如何理解边车模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ServiceMesh的关键之如何理解边车模式”吧...
    99+
    2024-04-02
  • 如何理解设计模式之桥模式
    本篇内容介绍了“如何理解设计模式之桥模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!举个例子桥模式的主要...
    99+
    2024-04-02
  • win10飞行模式快捷键如何关闭
    本篇内容主要讲解“win10飞行模式快捷键如何关闭”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“win10飞行模式快捷键如何关闭”吧!win10飞行模式快捷键关闭教程首先点击左下角开始,选择“设...
    99+
    2023-07-01
  • Java Volatile关键字如何理解
    Java Volatile关键字如何理解,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。正文在谈 Volatile 之前,我们先回顾下 Java 内存模...
    99+
    2023-06-22
  • 如何理解Java设计模式的解释器模式
    本篇内容主要讲解“如何理解Java设计模式的解释器模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解Java设计模式的解释器模式”吧!一、什么是解释器模式定义:给定一个语言,定义一个文法...
    99+
    2023-06-25
  • 如何理解Vue简单状态管理之store模式
    目录概述1. 定义 store.js2. 组件使用 store.js3. 实现效果概述 store 状态管理模式的实现思想很简单,就是定义一个 store 对象,对象里有 state...
    99+
    2024-04-02
  • 如何理解JavaScript的Mixin模式
    本篇文章为大家展示了如何理解JavaScript的Mixin模式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 在 JavaScript 中,我们只能继承...
    99+
    2024-04-02
  • 如何理解Java设计模式的状态模式
    本篇内容介绍了“如何理解Java设计模式的状态模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、什么是状态模式定义:当一个对象的内在状态...
    99+
    2023-06-25
  • 如何理解Java设计模式的享元模式
    本篇内容介绍了“如何理解Java设计模式的享元模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、引言大家都知道单例模式,通过一个全局变量...
    99+
    2023-06-25
  • 如何理解Java设计模式的组合模式
    这篇文章主要介绍“如何理解Java设计模式的组合模式”,在日常操作中,相信很多人在如何理解Java设计模式的组合模式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解Java设计模式的组合模式”的疑惑有所...
    99+
    2023-06-25
  • 如何理解Java设计模式的桥接模式
    这篇文章主要讲解了“如何理解Java设计模式的桥接模式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解Java设计模式的桥接模式”吧!一、什么是桥接模式桥接模式(Bridge Patt...
    99+
    2023-06-25
  • 如何理解Java设计模式的装饰模式
    这篇文章主要介绍“如何理解Java设计模式的装饰模式”,在日常操作中,相信很多人在如何理解Java设计模式的装饰模式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解Java设计模式的装饰模式”的疑惑有所...
    99+
    2023-06-25
  • 如何理解Java设计模式的单例模式
    这篇文章主要讲解了“如何理解Java设计模式的单例模式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解Java设计模式的单例模式”吧!一、什么是单例模式单例模式是一种常用的软件设计模式...
    99+
    2023-06-25
  • 如何理解Java设计模式的命令模式
    本篇内容主要讲解“如何理解Java设计模式的命令模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解Java设计模式的命令模式”吧!一、什么是命令模式命令模式是一个高内聚的模式,其定义为:...
    99+
    2023-06-25
  • 如何理解设计模式之把类作为参数的抽象工厂模式
    本篇内容主要讲解“如何理解设计模式之把类作为参数的抽象工厂模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解设计模式之把类作为参数的抽象工厂模式”吧!这...
    99+
    2024-04-02
  • 如何理解Mysql debug模式
    如何理解Mysql debug模式,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 以debug模式编译 -D...
    99+
    2024-04-02
  • 如何理解分布式中的TCC模式
    这篇文章主要介绍“如何理解分布式中的TCC模式”,在日常操作中,相信很多人在如何理解分布式中的TCC模式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解分布式中的TCC...
    99+
    2024-04-02
  • 如何理解Java设计模式的职责链模式
    本篇内容介绍了“如何理解Java设计模式的职责链模式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、什么是职责链模式客户端发出一个请求,链...
    99+
    2023-06-25
  • 如何理解JavaScript的设计模式
    本篇文章为大家展示了如何理解JavaScript的设计模式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  今天我们就聊一下这三个设计模式  单例模式 / 组合模...
    99+
    2024-04-02
  • 如何理解js的继承模式
    本篇内容主要讲解“如何理解js的继承模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解js的继承模式”吧!一、前言相信很多人在遇到面试中都遇到过被问到过...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作