ThoughtWorks技术日常部署运维

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

2018-10-07  本文已影响4人  极客人

本文翻译自: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用户直接在云中运行容器。

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

解放生产力

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

这些革命中的都有一个共同特点:它们都为软件工程师赋予了更多的控制权,降低了对服务器的系统管理员,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实例上随机部署(默认情况下),将面临以下问题:

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

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

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

让它们“漂”起来

事实证明,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可能对您更有益:

彩蛋

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

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

上一篇下一篇

猜你喜欢

热点阅读