Service Mesh所应对的8项挑战

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

Lori Macvittie

微服务架构是把双刃剑,我们享受它带来的开发速度(development velocity),却也不得不面对服务间通讯带来的复杂性问题。

目前大多数扩展容器化微服务的架构多是基于proxy-based复杂均衡器实现的。在这些架构的问题在于,容器环境内部伸缩往往依赖于IP tables,并受制于传统网络层。

所有这些代理提供相同的核心功能:扩展容器环境中的分布式服务。这些服务是一种短暂的构建(ephemeral constructs),实际上并不存在——除了在定义它们的资源(配置)文件中。基于IP tables的扩展解决方案的问题是,这些服务是7层(HTTP)构造,通常充当单个API调用的“后端”,而非整个应用程序。

正如我们所知道的,从客户端显示为单个、整体构造的应用,实际上由许多不同的(和分布式的)微服务组成。有些服务是纯内部的,供其他服务使用,这意味着要在容器环境中进行大量的service-to-service通信。

在这些环境中,一切都是HTTP/HTTP2之上的api,因此我们需要L7(HTTP)路由。我们还需要一致的安全、身份验证和策略执行。所有这些都是基于IP tables的方法无法实现的。

针对种种微服务架构服务间通讯的问题和难点,目前出现的一些Service Mesh相关开源项目已经开始着手解决这些挑战,核心集中于以下8个方面:

  • 构建 - 除了将策略与CI/CD工具链集成并确保配置的声明性模型,以便将service mesh视为一层基础设施之外,构建并不是Service Mesh的“强项”
  • 测试和集成 – Service Mesh可以帮助确保开发、测试、生产之间一致的策略。分阶段部署这种方法在过去运作良好,但它是将延迟插入部署过程的障碍之一。企业正在寻找一种将服务直接部署到生产的方法,并采用流量控制和回滚机制来处理故障。
  • 版本控制 - 服务网格可以作为基本API网关,根据API版本等变量路由流量,甚至可以翻译版本,以便在API版本过渡期间提供帮助。客户端升级并不总是强制的,这意味着会存在多个版本。Service Mesh可以将对旧API版本的请求转换为最新版本,以帮助降低维护同一API的多个版本的成本和负担。
  • 部署 - 得益于HTTP能力,Service Mesh是实现蓝/绿部署,金丝雀测试和流量控制的好方法。
  • 日志记录 - 分布式日志记录始终是一个问题,而且在实例生存时变化很大的环境中,它会更加麻烦。Service Mesh提供了一个通用的集中位置来实现日志记录以及执行请求跟踪等功能的能力。
  • 监控 - 监控是应用扩展的核心之一。虽然应用可以通过实现某些功能(重试、断路等)来处理服务不可避免的故障,但会给应用带来不必要的负担。Service Mesh承担了service-to-service通信的负担,并提供监控,其目标是在生产中专注于MTTD和MTTR,因为在生产中运行很困难,故障是不可避免的。
  • 调试 - 系统越复杂,调试就越困难。Service Mesh可以帮助进行根本原因分析,使用分析和遥测提供统计数据和故障前通知,并隔离容器(而不是杀死容器),以便对其进行彻底检查。这在由于内存泄漏缓慢导致故障的情况下特别有用。
  • 网络 - 网络仍然是容器的关键,可能比在不太复杂的环境中更为重要。从该网络中抽象服务的愿望意味着您不希望在每个服务中实现许多移动部件:服务发现、SSL和证书管理、断路器、重试、健康监控等。引入需要包含与网络相关的功能会增加微服务,并引入额外的架构和技术债务。服务网格承担了这些功能,并提供了所需的规模和安全性,而不影响开发。

Service mesh是一个令人兴奋的演变,它结合了云和容器的现代原则和坚实的规模基础。随着2018年以来容器技术的普以及对企业级应用扩展和支持的需求,Service Mesh的未来值得期待。

  • END -

关于Rainbond

Rainbond是一款以应用为中心的开源PaaS,由好雨基于Docker、Kubernetes等容器技术自主研发,可作为公有云或私有云环境下的应用交付平台、DevOps平台、自动化运维平台和行业云平台,或作为企业级的混合云多云管理工具、Kubernetes容器管理工具或Service Mesh微服务架构治理工具。

  • Rainbond项目网站
  • 试用Rainbond公有云
    • 注册或使用Demo账号/密码登录:rainbond-demo/rainbond-demo
  • Github
  • 码云
  • 文档
  • 微信群: 添加微信“zqg5258423”并接受邀请入群

  • 技术 Service Mesh真的是云原生应用的绝配吗?
  • 技术 Service Mesh微服务架构的崛起 2018/0706
  • 技术 Service Mesh:什么是Sidecar模式 2018/06/21
  • 技术 开源PaaS Rainbond v3.6.0正式发布,Service Mesh开箱即用 2018/06/20
  • 技术 解读Rainbond ServiceMesh微服务架构_开源PaaS Rainbond 2018/05/15
  • 技术 Pinpoint-java性能分析最佳实践_开源PaaS Rainbond 2018/05/08
  • 技术 通过Minio搭建私有化对象存储服务_开源PaaS Rainbond 2018/04/26
  • 技术 揭秘高可用负载均衡组件Rainbond-Entrance_开源PaaS Rainbond 2018/04/25
  • 技术 Rainbond插件体系设计简介_开源PaaS Rainbond 2018/02/24
  • 技术 Rainbond如何对接外部Maven仓库_开源PaaS Rainbond 2018/01/18
  • 技术 Spring Boot框架配置MySQL_开源PaaS Rainbond 2018/01/10
  • 技术 基于Midonet的多租户网络设计_开源PaaS Rainbond 2018/01/09

转载于:https://my.oschina.net/zhouyq/blog/1861476

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/277595.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

什么叫内部银团_什么是紫钛晶?紫钛晶是不是天然水晶?

都说紫钛晶是紫水晶与钛晶的结合,听上去好像这种水晶不是天然的,像是人工合成的,事实上并非如此,紫钛晶也是天然形成的水晶,由于内部的包裹体是金色的,因此被称为紫钛晶。和菩心晶舍家的晶舞倾城一起了解紫…

如何使用Squid服务来构建=》传统和透明代理服务器,通俗易懂!

1、缓存代理概述: 作为应用层的代理服务软件,Squid主要提供缓存加速和应用层过滤控制的功能 2、代理的工作机制: (1)当客户机通过代理来请求web页面时,指定的代理服务器会先检查自己的缓存,若缓…

Bootstrap开发框架视频整理

最近到客户处进行实地培训,整理了很多培训的材料,现将它们录制相关主题的视频,作为我的Bootstrap开发框架的知识补充,希望给感兴趣的朋友进行了解。培训内容主要包括基础框架部分、MVC框架部分、Bootstrap框架部分、Bootstrap重要…

【c基础】入门语法

%d:占位符 表示要输出一个整形数。 %f:为float 浮点数 %lf:为double型 双精度浮点数 \n:换行 const:定义一个常量,一旦被初始化就不能修改,只读的变量(read-only variable)。 整数运算 的结果是整数 如果有小数就抛弃没有考虑四舍五入。 一&a…

day22 Java学习 IO流(序列流)

IO流(序列流) 序列流: * 可以把多个字节输入流整合成一个,从序列流中读取数据时,将从被整合的第一个流开始读,读完一个之后继续读第二个。 整合方式: * Seq uenceInputStream ( InputStream &am…

Unraveling the JPEG file

(文章还剩实践部分没写,答辩过后补上...) JPEG文件在当下数字化生活中是无处不在的,但是在熟悉的JPEG面纱背后,隐藏着一些算法,它们去除了人类眼中无法察觉到的细节。这产生了最高的视觉质量与最小的文件大小。让我们来看看这一算…

mysql interval 3 day_Mysql之INTERVAL与DATE_SUB与EXTRACT函数的使用

1. INTERVALINTERVAL代表的是时间间隔MySQL中的时间间隔类型有如下几种:1.1 利用INTERVAL做时间的加减法示例:加法:SQL>SELECT DATE 2018-11-01 INTERVAL 10 11 DAY_HOUR;结果:2018-11-11 11:00:00减法:SQL> select date 2018-11-11 11:00:00 -INT…

0727日志

为什么80%的码农都做不了架构师?>>> c端线上地址 http://x.diandanme.com/fe/?d183#/ 什么时候来需求,我做好准备了吗? eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC94LmRpYW5kYW5tZS5jb21cL2FwaVwvd2VjaGF0XC…

Python基础学习总结__Day3

一、集合 1.特性:无序且天生去重,格式为{} 2.作用: (1)去重 (2)关系测试 3.可调用函数(常见对列表操作) (1)取…

day8网络编程,面向对象1

一.只是回顾 1.导入模块的顺序,首先从当前目录下找,再从环境变量里面找,使用"sys.path.insert(0,需要导入的环境变量)"加入需要导入文件的环境变量; 2.如果不同项目中有相同的文件,需要导入文件,需要将非当前项目中右键添加的环境变量取消,将当前的环境变量添加上去;…

ES语法及-IK分词器

{"query": {"query_string": {"default_field": "title",//全文搜索"query": "器大"}} } "id":1, "title":"Elasticsearch是一个基于Lucene的搜索服务器", "content":&q…

python多任务编程_python线程的多任务编程

多任务多任务介绍对于人来说,一边听歌,一边跳舞就是多任务。对于电脑,简单的说,同一时间执行多个程序处理数据叫做多任务多任务理解单核CPU单核cpu在处理多任务的时候是根据时间片轮转的方式进行的,比如执行QQ1us&…

简单分析Guava中RateLimiter中的令牌桶算法的实现

为什么80%的码农都做不了架构师?>>> 令牌桶算法是网络流量整形(Traffic Shaping)和速率限制(Rate Limiting)中最常使用的一种算法。典型情况下,令牌桶算法用来控制发送到网络上的数据的数目&am…

gcc oracle mysql_Linux下C语言访问Oracle数据库Demo

前提条件1. Linux环境已经存在,安装好了Oracle本demo 运行环境本地环境 RedHat LINUX AS 4 ,ORACLE 10G本地数据库sid orcl,ip:127.0.0.1,用户名:kingbi,密码:kingbi,表dsd_test. 显示表dsd_test 的所有记录.步骤:(1) 创建表 …

炼数成金数据分析课程---16、机器学习中的分类算法(交叉内容,后面要重点看)...

炼数成金数据分析课程---16、机器学习中的分类算法(交叉内容,后面要重点看) 一、总结 一句话总结: 大纲实例快速学习法 主要讲解常用分类算法(如Knn、决策树、贝叶斯分类器等)的原理及python代码实现 1、什么是分类? 分…

NFS配置详解

1、NFS服务介绍1.1 什么是NFS?NFS是Network File System的缩写。中文意思是网络文件系统。它的主要功能是通过网络(一般是局域网)让不同的主机系统之间可以共享文件或者目录。NFS客户端(一般为应用服务器,例如web&…

idea用法

更新gradle的依赖后,刷新项目引入jar包的方法: view--Tool Buttons 在右侧 Gradle 点刷新 转载于:https://www.cnblogs.com/z360519549/p/10994897.html

免费下载!5本阿里技术好书,带你看更大的世界

共享、开源是互联网技术发展的重要精神。在过去,25000多万名阿里工程师,撰写了一系列精品技术丛书,从算法、研发到职业人生随笔,应有尽有。目前该系列丛书已全部开放下载,供技术人免费阅读。 今天小编整理了其中的五本…

乌班图系统16.04安装

本例jiyu基于Ubuntu16.04 64位版本为例进行安装,安装的方式有多种,本文使用光盘进行安装安装前应准备好,将Ubuntu的镜像文件刻成光盘,然后将光盘放入光驱,并设置服务器从光盘启动,开机到如下界面:按Enter键到下一步,如…

使用maven构建项目候,jar包错误的解决办法

1、删除架包,重新下载,右键项目点击"run as"中的“maven clean”,然后再maven中找到Update Project 2、可以在代码中,把鼠标放到报错的架包上 点击划红线部分,进行安装 转载于:https://www.cnblogs.com/qingqian/p/1099…