AWS Fargate告诉你:什么是容器即服务

本文翻译自:Freecodecamp, 原文地址:An intro to Amazon Fargate: what it is, why it’s awesome (and not), and when to use it, 英文原作者为 Emmanuel Marboeuf

当亚马逊在2017年底的AWS re:Invent大会上和EKS一起宣布 Fargate的时候,它还备受冷落,当时我所关注的博客和大佬只是轻描淡写地说:

哦,有这么个新玩意,它将允许ECS用户直接在云中运行容器。

作为开发人员,这真的让我大吃一惊。让我们看看为什么。

解放生产力

我觉得软件开发领域已有五次重大革命,大大提高了开发者的工作效率,并以最高效率编写与部署应用。他们都解决了一系列的重大问题:

  • 云服务(IaaS)的出现:解决了基础架构的成本和可扩展性问题
  • 开源社区,会议,工作坊,技术博客,StackOverflow等:让知识惠及到更多人
  • 版本控制系统,协作工具,持续集成工具 解决了项目的并行开发和集成问题
  • 容器化架构
  • 无服务器计算服务(PaaS) 降低服务器和系统管理成本

这些革命中的都有一个共同特点:它们都为软件工程师赋予了更多的控制权,降低了对服务器的系统管理员,DevOps,IT支持人员等的依赖。

所以,Fargate算其中的哪一种呢?

你的“船”才是问题所在

Life jacket is advised

Docker使容器技术普及开来,便很快成为开发中被广泛采用的新标准。

不久之后,随着Kubernetes的成功,AWS推出了自己的(更基本的)容器管理服务:Amazon Elastic Container Service(ECS),它引入了任务(Task)的概念。

一个任务可以是一起工作的容器的任何实例。它可以是从运行一个服务的Web应用,多个微服务,数据库和反向代理,还可以是定期运行的批处理shell脚本。

作为使用ECS的“老司机”,我很喜欢它,曾经在一段时间内用得很爽,但到最后,我发现在管理EC2 Instance的同时,还必须管理一些额外的层(任务和容器),这让ECS变得越来越复杂。(译者注,请参考AWS“层”的概念

同时,我对ECS的安全性也不甚满意,层越多,就越要保持警惕,而每一层都带来了更多的复杂性,以及误配置、漏洞的可能性。

使用ECS在集群中运行中的EC2 实例(Instance)配置弹性伸缩时,每个实例上可以承载多个不同的Task,每个Task都可以运行多个容器。
由于任务(Task)会在具有可用资源的相同类型的EC2实例上随机部署(默认情况下),将面临以下问题:

  • 一个集群必须遵循相同的弹性伸缩规则,伸缩的EC2实例类型必须相同。
  • 有些容器需要完全不同的资源(译者注,AWS将网络、虚拟机、负载均衡都称为资源),但仍需要协同工作。
  • 某些容器不一定遵循相同的弹性伸缩规则。
  • 有时同一任务中的多个容器都需要有自己的负载均衡,无法为同一任务设置多个负载均衡器。

面对这些问题时,首选的解决方法是:

  • 根据需求手动部署一些具有不同资源的EC2实例
  • 将这些EC2实例添加到您的集群
  • 为任务运行一个容器
  • 手动链接到您的EC2实例
  • 在ECS上配置复杂的任务策略,把不用任务根据他它们的需求配置在适当的EC2上

这需要大量、繁琐的工作,还不易维护,这违背了使用容器的初衷。

有人不得不提出一个更好的主意。

让它们“漂”起来

事实证明,AWS团队在过去一年中也遇到了同样的问题,他们考虑过并致力于解决这些问题:

我们怎样才能运行容器而不必担心服务器和集群?

这就是AWS Fargate的意义所在。它完全抽象了底层基础架构,你可以把每个容器视为一台机器。

你只需定义每个容器所需的资源,它将为你完成复杂的任务而不必再管理多个“层”之间的访问规则,您可以像在单个EC2实例之间那样调度容器那样。

Fargate上的容器

这就让你的容器像水面上的船只拥有自己的帆、船舵、船员一样,自己可以漂流到想要去的地方。

容器即服务(CaaS)

我一直坚信容器即服务(CaaS)是开发人员梦寐以求的、真正的平台及服务(PaaS)。它允许开发人员直接在云中部署他们的容器,而不必担心底层细节。

当然,已经有很多技术允许您在云上无缝运行代码,而不必担心扩展或服务器管理(比如HerokuLambda,甚至以自己的方式使用Google应用引擎),但它们都有局限性。

  • 必须选择丧失一点灵活性
  • 必须使用它们所支持的语言
  • 无法使用它们所支持的语言完成拟定项目,因为可能您的项目需要在指定操作系统系统上可用的低版本的原生库
  • 您的项目采用了尖端技术,未来几年将无法为大众所用
  • 其中一些平台非常非常昂贵,特别是在扩展时

Fargate(或CaaS)为您带来两全其美的方案。

容器化架构为您提供所需的灵活性和控制权,它允许您在任何类型的系统中使用任何技术。而容器技术能确保你的应用在每个主机上具有相同的行为,无论是开发(Dev),测试(Testing/QA),预发布(Staging)还是生产(Production)环境。

我觉得这一点对众多的科技初创公司至关重要。事实上,有时您的竞争优势之一就是,您参与开发出最先进的技术,或者是把机智地原有的技术用在新的应用场景中。

无服务器部署使您可以专注于编写优秀的代码,没有配置,易于扩展。

限制

CaaS vs PaaS

也许确实你放弃了真正的“平台即服务”的一些优势,比如您仍然需要手动更新容器的镜像,有时您必须编写自己的Docker镜像。如果您不了解系统管理的基础知识,这的确很麻烦。

但是,这也意味着您可以放手地做任何您能想做的事情,并且在您想要使用的系统上,保证语言,工具,库和版本中的灵活性和自由度

成本

让我们直面这样的现实:云服务(IaaS)比拥有自己的基础架构更昂贵(如果你想要按需扩展你的基础架构)。同样的道理,不必关心配置、管理和扩展服务器是要需要付出代价。如果你的应用十分简单,云服务并不是最优解。

Fargate实好,但是其价格几乎是等配置EC2实例的价格的 4 倍(例如t2.medium)这让我们很难抉择,让我们期待它能够降价。

Fargate 和 EC2 价格对比 (USD)

我应该将所有ECS任务都切换到Fargate吗?

当然不是。如上所述,在某些情况下,您的成本将增加三倍以上,所以在它们降低成本之前,您可能最好使用标准EC2实例。

但是,在以下情况下,Fargate可能对您更有益:

  • 如果您无法很好地伸缩你的ECS任务,会导致大量空闲的CPU或内存,而使用Fargate,您只需为在任务中定义的资源付费
  • 对于按需或按定时计划运行的任务,并不需要一直运行着的EC2实例。使用Fargate,您只需在任务运行时付款。
  • 适用于有内存和/或CPU使用率峰值的任务。这仅仅是因为使用Fargate可以在这类情况下节省您配置和管理的时间。

彩蛋

对于那些喜欢Kubernetes而非ECS的人来说,Fargate很快就会支持EKS了。

原文:http://wangbaiyuan.cn/an-intro-to-amazon-fargate-when-and-why-use-it.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 198,848评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,529评论 2 375
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 145,824评论 0 327
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,329评论 1 268
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,227评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,879评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,218评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,877评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,159评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,155评论 2 315
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,987评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,736评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,273评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,407评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,663评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,158评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,517评论 2 339

推荐阅读更多精彩内容