如何在企业中尝试无服务器技术
原文:Serverless 101: How to Get Serverless Started in the Enterprise
起初,世上有了裸机,这很好。
独占的服务器很快、很可靠,也很安全——毕竟是独占。但是平心而论,这时候的配置和扩展非常麻烦。对于敏捷和弹性的渴望,催生了虚拟机,云供应商们适时推出了IaaS(基础设施即服务),云端+自助的模式也就自然而然的随之面世了。IaaS 的沃土中,产生了 Amazon Web Services、编排技术、以及基础设置即代码 (IaC: infrastructure as code);容器化初露端倪、PaaS(平台即服务)也应运而生。当然了,一切都很好,更好了。只不过,开发者们大声疾呼,他们需要语言无关的服务端点、水平伸缩以及实时的服务计费。
祈祷有时候是有效的,这世界得到了一份大礼:无服务器计算,也被称为 Function as a Service (FaaS)。运行时部分只做执行,不保存数据。换个说法就是,AWS、Google Cloud 或者 Microsoft Azure 负责动态的管理资源的分配和分布。
从前使用的基于预测的预付费服务方式已经不适合无服务器计算,取而代之的是根据实际用量进行的即时计费方案。2018 年开始,我们开始将其视为基础设施。
并非魔法
首先,这个名字很有误导性:无服务器计算不是魔法,并不是由神秘的月光驱动的——服务器还是需要的。
这个说法大行其道的原因是,这一架构隐藏了服务器管理以及容量规划和决策等工作。无服务器计算中所谓的“无服务器”,是针对用户和开发者来说的,对他们来说,再也不用花力气、甚至不用知道基础设施了——服务器已经成为一个抽象概念了。无服务器架构中的代码可以和微服务这样的传统的代码部署一起使用——或者可以完全使用无服务器架构来构建应用,就完全不需要关注服务器的问题了。
无服务器架构的真正价值在于时间效率
Bitnami 的云计算高级总监 Sebastien Goasguen 说:“我认为这是一种最小化的 PaaS,一种类似胶水的软件”。“无服务器架构中的关键动作就是——从云中发生了事件,触发了函数的执行。”,Goasguen 描述了 AWS 中的一个场景:把图片保存到存储设施中,接下来调用一个函数来进行图片的缩放。无服务器系统中会处理把这些代码自动的注入到运行时环境中(服务器或者容器),然后进行公开,让函数可以被外部调用。
不是魔法是什么?
传统云计算和无服务器计算的主要区别来自于客户:没人愿意为自己没使用的资源买单。从前我们需要对容量和资源需求进行预测,然后根据预测来采购基础设施——可能是自有也可能是公有云。我们前面的例子中,就是要在 AWS 启动服务器,令其保持就绪,这样才能随时使用这一服务来完成图片的缩放任务——只有在这时候才真正的调用了这一函数。
无服务器计算服务把你的函数作为输入,执行其中的逻辑,然后返回函数的输出,最后关掉。用户只会收到函数执行期间的消费账单。
随用随付,只为实际消费买单,这是个伟大创新。然而 Goasguen 和其他一些 Cloud Native 专家强调,无服务器技术的真正价值不在于成本效率,而在于时间效率 。
好像时光机?
是的有点像。或者更像一个通向未来的 Portal,无服务器技术让客户专注的用各种 AI、机器学习等神奇的新技术构建应用,而不是为了跟随时代步伐,永远的建设和翻新基础设施。
无服务器技术的另外一个时光机的特性就是缩短从代码开发到生产运行的时间。简单到了一句话:“这是代码,拿去运行吧”,几乎没有基础设施方面的拖拖拉拉。
Oracle 的无服务器技术副总裁 Chad Arimura 说:“基本思路,开发人员把编写好的代码推送给无服务器服务提供商,其余的部分交给服务商完成。”,另外他还补充说,常见的依赖内容,例如服务器和存储,也会在无服务器计算的环境中提供无缝支持。
“幕后有专家团队和大量的自动化工具来运维这些系统,从而把开发者从这些问题中解脱出来”,Arimura 接下来说,“无服务器的魔术一般的体验,让这一概念的热度持续上升。“
感受 FaaS 平台的力量
Docker 简化了分布式应用的打包和依赖管理,Kubernetes 让企业能够在生产环境中运行这些应用,但是他们的易用性还是不够。Bitnami 的 Goasguen 说:”Dockerfile、基础设施的细节、Kubernetes 的清单——这些对开发思维的受众来说还是稍显复杂的。“
无服务器计算的核心,就是 FaaS 平台。具体点说就是 AWS Lambda 或者 Google Cloud Function,所做的事情:资源管理、负载均衡以及多线程处理;而开发者只需要为雇主专注完成代码即可。
iguaz.io 是一个致力于优化云端性能的持续数据平台,其创始人和 CTO Yaron Haviv 提出:
- 无服务器平台接收函数代码(FaaS 中的 “F”),为这些代码提供所有的依赖支持(库、内存、配置等),然后构建一个容器化的应用包(通常是 Docker 格式)。
- 函数的触发方,可以是其他的平台服务,例如对象存储或者数据库;也可以是一个外部的 HTTP 请求。无服务器平台会把请求转发给一个可用的函数微服务上去。如果没有可用的实例,就部署一个——也就是冷启动。
- 无服务器平台需要处理好微服务的故障恢复、按需伸缩、日志和监控,并在代码变更后执行滚动更新。开发者除了函数本身,所有其他问题都无需关注。
无服务器架构的不足
无服务器并非银弹,还是有一些不足的。有专家说,云服务商经常会缩减一些使用率不高的环境的资源,他们还会限制用户的资源总量,这样就产生一个矛盾——高性能和高延迟同时出现。另外云服务商的监控、排错和安全都会有自己的思路,可能让用户觉得很古怪。这些问题的根源就是:公有云是不受客户控制的。
Amazon Lambda 跟无服务器计算是同时进步的,提供了一个多数人都可以接受的模型。 因为 Lambda 是无服务器技术的开创者,所以他的不足也自然而然的被视作无服务器技术的不足:缓慢的冷启动、低性能、短命的函数以及千篇一律的触发器。目前认为这些限制是所有无服务器平台的通病,然而实际上,这是实现过程的一些选择问题。我们应该注意一些新的无服务器平台,例如 Nuclio,他提供了更丰富的用例。这些平台的限制更少,提供更好的性能,同时能够运行在多种云甚至是私有云上。
”极客们喜欢这个,但是企业还在试水——他们连 Docker/K8S 还没用上呢,就来到无服务器时代了,“,Haviv 说。”和任何新技术一样,我们需要首先争取到早期试用者——他们通常更敏捷、更能承受风险,然后才能接近大众。而要获得早期试用者,需要建立信任、看到证据、解决性能、安全等方面的疑难等等。“
显然无服务器技术正在日新月异的向前发展,肯定无法十全十美。虽然下面的话不一定是什么缺点,但却是能让董事们无法安坐在 Aeron 椅子的一个问题:”数字化转型总在被新技术打断,因此企业必须更加敏捷和并正视风险,“Haviv 指出。
”有趣之处在于,Docker/K8S 的抽象是非常复杂的,而无服务器技术虽然更加新潮,却更加简单、更易接受。“
我的公司是否适合无服务器技术?
暂时不提企业适合无服务器技术是好是坏,我们先来看看领导厂商。
Oracle 的 Arimura 认为:”字面上来说,所有组织和公司,只要需要编写软件的,就都适合使用无服务器技术“,”目前的文化和云原生之间的距离越远,就越难应用无服务器技术“,换句话说,如果一个公司没有使用公有云、也没有在内部试用 Kubernetes 或者 Docker 这样的新技术,那么无服务器可能就不是一个合适的尝试。
”这是一个新架构,需要不同的思维方式。最简单的例子:如果一个单体应用拆分为十个微服务,再分为一百个函数,这些单元都具有自己的发布周期和复杂的依赖关系。这很明显需要成熟稳定的持续构建、交付以及自动化系统的支撑。“,Arimura 说,”敏捷创新是无服务器技术的必要支撑,否则造成的害处可能要多余带来的益处。“
”DevOps 的目标不是 NoOps,这完全是个错误思路,无服务器技术更加需要 DevOps 的支持。“
来自 Bitnami 的 Goasguen 补充,采用无服务器技术(尤其是 AWS Lambda)的大多数公司都是以开发者为中心的,他们在此之前已经在应用 AWS,现在使用无服务器计算把服务连接在一起。所以机会就是,如果现在还没有使用 AWS,那么你不需要无服务器技术,然而你仍然应该保持跟踪,开始评估,识别企业中可能存在的事件源,看看如何使用这些事件构建完整的应用管线。
企业如何试水无服务器技术?
”不要把一个单体应用整体转化为微服务或者函数“,Arimura 建议,”使用公司的最重要项目来学习新架构是不明智的,尤其是在公司的文化还在 DevOps 的尝试阶段。“
从小处入手,例如一点自动化任务,或者一些市场活动以及一些事件驱动的用例等。
New Stack 的无服务器技术系列,将协助你的公司探索无服务器的新领域。