如何选择最合适的Serverless服务?
《如何选择最合适的Serverless服务?》要点: 通过迅速灵活以及容量巨大的弹性伸缩,无服务器架构能很好地解决关键功能的性能瓶颈,但它并不是完美的:不仅需要修改设计去适应它,对熟悉的编程模型进行调整,还要解决诸如规划预算、安全等等问题.但总的来说,它为云上的应用提供了另一种选择——并且具有难以抵挡的诱惑:极大地简化应用从开发到部署和维护的整个过程. 将编写代码和部署应用的整个过程简化是每个开发人员的梦想,而无服务器架构(Serverless)正是这样的解决方案,在采用这种架构的时候需要考虑它的局限,费用问题以及安全问题. 信息技术在不同领域的发展不尽相同.诚然,事实一直如此,因为人们为当下的问题所找到的可行的解决方案,通常先于这些问题本身就已经存在了.与虚拟化、云计算等技术的缓慢进步相比,编程语言几乎是原地踏步了十年.直到新一轮的编程语言和方法诸如Python,Ruby,Node,Swift的出现才打破这一局面.这两个领域看似毫无关联,然而我们即将看到二者共同演变并结合在一起开花结果. 这个新的结合领域就是无服务器计算(Serverless).易于部署的容器实例集合、无处不在的基于REST API的外部服务、易于实现REST API的新编程语言使得以 REST API提供接口成为一种简单而可行的选择.这些技术相互结合,创造了一种全新的计算形式. 我们已经很熟悉这种新的编程形式的诸多方面(例如如何设计和实现REST API,如何设计实现微服务),但是仍有一些方面并不为人熟知. 从Node.js中学到的但这个应用提供的并不是REST API,它只是简单地根据不同的请求内容响应包含不同内容的HTML页面.结合REST之后,Node应用便成为一个计算结点.不变的是,当收到请求时,它便执行逻辑,然后退出.同时,作为基础设施的部分,它会保持对特定端口的监听. 基础设施然而,为了实现一个简单但完整、可运行的Node应用(或者 Python / Djang / Java / Spring / RoR 等),还需要进行网络配置,防火墙配置,操作系统配置和调整,存储配置,并且如果你使用了网络应用防火墙(WAF: Web Application Firewall),还需要配置WAF.尽管,DevOps能使所有这一切更容易一些,但请试想一下,如果你根本不需要做这些额外的配置,那将会怎样? 无服务器架构这对开发者无疑有着巨大的吸引力.编写代码后,无需进行那些看似必须的配置(无论是物理环境,虚拟环境的还是云端环境)就能部署,是众多开发者的梦想.这也不禁让人想起一些现实世界中的例子.首当其冲的就是应对高峰期的性能瓶颈.假设你有一个完美运行的在线订单系统,在销售高峰期(比如黑色星期五),由于验证收货地址的时间过长,系统经常陷入崩溃. 如果你有一个无服务器函数(serverless function),它仅返回输入的地址是否有效,你就可以将地址验证交给它来处理,那该多好? 甚至,该功能还允许快速扩展到几乎无限容量(当然,网络带宽还是要考虑的)! 现在,这个瓶颈不再是问题,你只需要为这个函数实际使用的计算资源(CPU时间)付费. 这意味着调用得越多,支付的费用就越高,但是在大部分的时间里,费用都很少. 你只需要为真实使用的计算资源付费. 如果所有这一切以可接受的价格让你在你的站点上或者云端完成,那该有多好!已经诞生了这样的产品(Microsoft Functions,AWS Lambda和nanoscale.io等)都提供了上述所有功能. 并非雨后彩虹
构建正确的应用将来,一些应用程序将完全采用无服务器架构,特别是对于相比使用云端实例更具成本优势的应用.即便没有这样的应用,尽可能少地在基础设施上配置资源也会变得更加划算.同时,将无服务器计算作为解决各种相对独立的功能引起的性能瓶颈的解决方案,或者用于测试在不需要增加基础设施预算的情况下,是否可以增加应用的容量.总的来说,在信息技术领域,对于如何正确地选择架构来实现业务目标,无服务器架构无疑是其中一种解决之道. 相关文章:
作者介绍:胡应明,趋势科技资深工程师,DockOne社区译者 文章来自微信公众号:Docker (编辑:ASP站长网) |