在精彩的软件容器世界中,当新项目涌现并解决你认为早已解决的问题时,这感觉就像地面在你的脚下不断地移动。在许多情况下,这些问题很久以前被解决,但现在的云原生架构正在推动着更大规模的应用程序部署,这就需要新的工具和方法。

微服务就是一个很好地例子。在此模型下,典型的应用程序或服务将被分解成可以独立部署的功能模块,这些功能模块能彼此分开扩展和维护,并且链接在一起时可以提供应用或服务的全部功能。

当使用容器来开发微服务时,后一块可能是棘手的。当它们可能散布在服务器节点集群中时,并且在它们的实例不断弹出时,随后被更新版本替换而下线时,该如何将所有组件部分链接起来?在面向服务的架构中(SOA),微服务可以被视为进化的继承者,这种任务类似于企业服务总线(EBS)所处理的任务,所以需要的是一种基于云原生版本的EBS。

这是一个相对新的开源项目Istio旨在填补的工作。它被正式的描述为服务网格,因为它的其中一部分分布在由容器管理的基础架构中,并且它开始着手于满足服务发现,负载均衡,消息路由,遥测和监控,以及必不可少的安全等需求。

Istio源自于谷歌和IBM之间的合作,实际上包含了一些现有的组件,特别是由乘车服务公司Lyft开发的组件。它以某一种形式存在了至少一年,最终在七月底达到1.0版本的里程碑,这意味着它终于被认为足够成熟,可以作为生产的一部分基础架构运作。

IBM研究员兼IBM云计算首席技术官Jason McGee告诉The Next Platform,云原生态系统已基本确定容器作为打包和运行的核心结构,而Kubernetes则作为管理容器的编排系统。但McGee解释说,还有第三块拼图还没有落地,这就是Istio的设计点。

“你如何管理在容器平台上运行的应用程序或服务之间的交互?”McGee问道。 “如果你正在构建微服务,或者你有一组应用程序,那么应用程序之间的通信会产生一大堆有趣的问题。你如何了解谁与谁之间进行对话,如何收集有关应用程序之间通信的数据,如何保护控制哪些服务可以相互通信的通信,以及如何使应用程序安全,尤其是我们今天拥有更多种的动态或分布式架构应用程序,你在公有云的何处能安放高质量的组件?”

McGee说他在IBM的团队几年前已经开始研究这个问题了,当时他遇到了谷歌的同行并发现他们正走在同一条道路上,但IBM主要关注流量路由,版本控制和A/B测试方面,谷歌则专注于安全和遥测。两家公司决定合并各自的努力,结果就是Istio的产生。

Istio由以下组件组成:

Envoy,被描述为边车代理,它作为代理部署在每个微服务实例旁边;

Mixer,它是一个核心组件,用于通过Envoy代理实施策略,并从中收集遥测指标;

Pilot,负责配置代理;

Citadel,是负责颁发证书的集中组件,它也有自己在每个节点的代理。

Envoy是由Lyft开发的组件,被McGee描述为“一种非常轻量的L4到L7的智能路由器”,它捕获来自与其配对的微服务的所有传入和传出通信,作为一种流量的控制方式,执行策略和收集遥测。Pilot是IBM提供的主要组件,可作为部署在基础架构中的所有Envoy代理的控制平面。

“如果你想象在一个服务网格中,你可能有一百个微服务,如果每个都有多个实例,你可能有数百或数千个这些智能路由器,你需要一种方法对它们进行全部编程,所以Istio引入了这个称为Pilot的东西。可以把它想象成程序员,所有这些路由器的控制平面。所以你有一个地方可以通过它来编程这个服务网络,然后围绕数据收集进行遥测,围绕安全进行证书管理,但从根本上说你可以利用这个智能路由层和这个控制平面来管理它。”McGee解释道。

Istio还有自己的API,允许用户将其插入现有的后端系统,例如用于日志记录和遥测。

根据谷歌的说法,Istio的监控功能使用户能够测量服务之间的实际流量,例如每秒请求数,错误率和延迟,还可以生成依赖关系图,以便用户可以看到服务之间如何相互影响。

Istio
通过其Envoy边车代理,Istio还可以在每个服务请求上使用双向TLS身份验证(mTLS),添加传输加密并使用户能够授权跨基础架构的每个请求。

Istio消除了开发人员担心实例之间的能否安全通信,解决了控制哪个实例可以与哪些实例进行通信,以及提供执行诸如金丝雀部署之类功能等需求。如果是发布新版本的特定微服务的代码,最初只更新实例的一部分,直到你对新代码运行可靠性感到满意,再更新其他部分。

应该注意的是,其他服务网格平台已经存在,例如开源端的Linkerd或Conduit,而微软有一项服务,被称之为Azure Service Fabric Mesh,目前作为其云平台上的技术预览。此外,服务网格代表了网络管道上方的抽象层,因此前提是已经为每个容器实例配置了网络接口,IP地址和其他网络属性。这通常意味着,无论何时创建新的容器实例,部署微服务还将需要一个单独的工具来自动配置网络。

然而,IBM希望Istio将成为云原生工具包的标准组成部分,正如Kubernetes那样,Kubernetes基于谷歌为自己的内部集群开发的Borg和Omega技术和其上面的容器层技术。

“从社区的角度来看,我的期望是Istio成为架构的默认部分,就像容器和Kubernetes已经成为云原生架构的默认部分一样。”McGee说。为此,IBM希望将Istio与其公有云所提供的Kubernetes托管服务以及其内部部署的IBM Cloud Private堆栈集成在一起。

“所以,你现在可以运行Istio,我们支持现在平台上运行Istio,但期望是在不久的将来,我们将Istio内嵌,所以每当使用我们的平台时,Istio组件就在那里,你可以利用它,并且不必负责部署和管理Istio本身,只需能够在应用程序中使用它。”McGee说。

谷歌已经添加对了Istio的支持,尽管只是将其标记为alpha版本,作为托管服务的一部分,该服务在其云平台上客户的Google Kubernetes Engine(GKE)集群中自动安装和维护。

Istio也获得了业内其他公司的支持,尤其是Red Hat,几年前它重新设计了OpenShift应用程序平台,以Docker容器和Kubernetes为基础。

Red Hat的Istio产品经理Brian Redbeard Harrington表示Red Hat打算将服务网格集成到OpenShift中,但Red Hat希望在正式使用前能看到一些粗糙点的改进,比如支持多租户技术。

“Istio现在的目标是他们所谓的软多租户技术,也就是说,我们希望在组织内部可以使用它,以便该组织内的两个不同的团队可以使用并信任它,只要没有一个组的行为过于恶意,他们就不会影响到彼此的服务。通过我们运行OpenShift Online的方式,我们让客户运行我们从未看过的代码,并且必须最后安排这两个客户并存,这是一个非常独特的多租户挑战。”Harrington解释道。

“我们需要对这个多租户有更高的信心; 我们需要对性能和稳定性有更高的信心。 我们还没有看到任何搅局者,但我们已经看到了可提供很多价值的领域,包括在进行规模测试和一些自动化回归测试方面,我们还在社区层面贡献了一个名为Kiali的项目,可视化的给出了Istio的内部运作,这只是我们所提供的产品的一部分。”他补充道。

换句话说,Istio是另一种开源工具,可以为那些希望构建云原生应用程序基础架构的用户添加选项菜单。像Red Hat这样的供应商将把它融入他们经过测试和支持的企业平台产品中比如OpenShift,而其他供应商则希望自己混合搭配并构建它。

原文地址:

https://www.nextplatform.com/2018/08/15/istio-aims-to-be-the-mesh-plumbing-for-containerized-microservices/
---------------------

容器云技术:容器化微服务,Istio占C位出道的更多相关文章

  1. 云容器云引擎:容器化微服务,Istio占C位出道

    在精彩的软件容器世界中,当新项目涌现并解决你认为早已解决的问题时,这感觉就像地面在你的脚下不断地移动.在许多情况下,这些问题很久以前被解决,但现在的云原生架构正在推动着更大规模的应用程序部署,这就需要 ...

  2. 《2016ThoughtWorks技术雷达峰会----微服务架构》

    微服务架构   王键,ThoughtWorks, 首席咨询师 首先微服务架构的定义,thoughtWorks在2012年3月的技术雷达中这样定义: “微服务架构是一种架构,它提倡将单一应用程序划分为一 ...

  3. 搞懂分布式技术28:微服务(Microservice)那点事

    搞懂分布式技术28:微服务(Microservice)那点事 微服务(Microservice)那点事 肥侠 2016-01-13 09:46:53 浏览58371 评论15 分布式系统与计算 微服务 ...

  4. Istio旨在成为容器化微服务的网格管道

    在精彩的软件容器世界中,当新项目涌现并解决你认为早已解决的问题时,这感觉就像地面在你的脚下不断地移动.在许多情况下,这些问题很久以前被解决,但现在的云原生架构正在推动着更大规模的应用程序部署,这就需要 ...

  5. 容器云技术选择之kubernetes和swarm对比

    swarm和k8s本质都是容器编排服务.它们都能把底层的宿主机抽象化,然后将应用从以构建好的镜像开始,最终以docker的方式部署到宿主机上.   应该选择哪种方案作为我们的容器云服务呢? 我觉得k8 ...

  6. 容器云平台No.4~kubernetes 服务暴露之Ingress

    这是容器云平台第四篇,接上一篇继续, 首先kubernetes服务暴露有如下几种方式: NodePort Loadbalance ClusterIP Ingress 本文紧贴第一篇架构图,只介绍Ing ...

  7. 微服务架构:基于微服务和Docker容器技术的PaaS云平台架构设计(微服务架构实施原理)

    版权声明:本文为博主原创文章,转载请注明出处,欢迎交流学习! 基于微服务架构和Docker容器技术的PaaS云平台建设目标是给我们的开发人员提供一套服务快速开发.部署.运维管理.持续开发持续集成的流程 ...

  8. 容器化VS微服务

    1 微服务 1.1 思想 开发人员自己测试.部署和运维自己编写的代码,即自己负责构建生命周期的全部. 1.2 Spring Boot 提供服务化的能力,即把容器.服务所需依赖和服务一起打包成一个jar ...

  9. 有容云-PPT | 当微服务遇见容器

    编者注: 本文为10月29日有容云高级技术顾问龙淼在Docker Live时代线下系列-广州站中演讲的PPT,本次线下沙龙为有容云倾力打造Docker Live时代系列主题线下沙龙,每月一期畅聊容器技 ...

随机推荐

  1. Windows 2008 Scheduled tasks result codes

    0 or 0x0: The operation completed successfully. 1 or 0x1: Incorrect function called or unknown funct ...

  2. HTML5学习总结——相关练习与项目

    一.小米商城项目 第一天示例代码: <!DOCTYPE html> <html lang="en"> <head> <meta chars ...

  3. RN如何固定底部的按钮

    如上图的底部新增按钮,要是放在web里那是相当简单,直接是用固定定位就行,但是在RN里是没有固定定位可言的. 方案一: 采用绝对定位,相对于最外层的定位在底部位置.(在部分安卓机上有问题,动态计算的高 ...

  4. sql 优化的几种方法

    .对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. .应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而 ...

  5. Python入门 —— 01简介

    Python 历史 python 的创始人为荷兰人吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为 ...

  6. Thinkphp5 对接百度云对象存储 BOS (上传、删除)

    首先下载SDK包可以在 官网下载,或者在项目根目录使用composer . composer require baidubce/bce-sdk-php 压缩包里面有五个文件,实际运用到只有两个,然后放 ...

  7. laydate5.0 设置最大最小值

    由于新版的laydate时间插件在初始化时已设置时间最大最小范围,且生成对象,无法重新渲染改变其日期最大最小值. 有网友经实验贴出如下方法可达成目的,故做记录. //开始时间 var startDat ...

  8. Python系列之入门篇——pytables及其客户端

    pytables及其客户端查看 pytables # ubuntu sudo apt-get install python-tables pip install flask flask-httpaut ...

  9. 最新版的stm32f1xx.h文件中取消了u8, u16, u32的类型定义

    使用芯片stm32f103zet6和stm32l151c8t6,在移植程序时发现,编译器提示u8未定义: 在Keil MDK 开发环境里,st定义无符号32位整形数据有很多种表示方法: 1 unsig ...

  10. 自添加LUCI菜单及编译为ipk

    目录 添加汉化编译为ipk配置文件入口函数界面文件Makefile 添加 添加自己的luci界面,有3个必要的要素: a配置文件.新建一个在/etc/config/abcdefg b入口函数.新建一个 ...