6岁!是时候重新认识下Serverless了
一、背景
Serverless 概念从2012年开始提出,真正推出相关云产品是2014年AWS推出Lambda。如果我们将 Serverless 比作一个婴儿,那么它已经6岁了。
虽然业界对Serverless尚无一致认可的定义,但是我相信大部分开发者在听到 Serverless时,会联想到Lambda,并且冒出“函数”、“按需(调用次数)收费”、“事件驱动”等关键词。确实当年刚刚诞生的Serverless就像下面可爱的“紫薯人”,紫色充满神秘感(当年刚推出的时候绝对是黑科技),让人印象深刻。

AWS的巨大影响力以及本身携带的一身黑科技,确实让人记住了 Serverless,但是也正因为诞生的时候太印象深刻,以至于现在提到已经6岁的 Serverless,很多人的印象还是停留在Serverless=Lambda或者Serverless=FC(Function Compute),这不得不说是某种遗憾。

今天企业都在全面数字化转型,整个技术架构体系都渴望依托云原生来获取巨大技术红利,Serverless从诞生的第一天起就是云原生的,所以我们有必要再系统的认识一下Serverless的理念以及这些年诞生的相关产品,相信不管你是前端、后端、架构师、SRE、CTO都会有所收获,并且在未来能更好的发挥Serverless的技术价值助力商业成功。
二、定义
业界一直在尝试定义Serverless,比如CNCF给出的定义是:NoOps 和Pay as You Run,还有伯克利说 Serverless=FaaS+BaaS。但是我想说,Serverless 其实无需再去定义,他本身就已经非常清晰明确:“Server+less”,他是一个理念,核心思想就是你不再需要关注 Server,作为对比的是 IaaS 时代,购买服务器,安装各种工具,再在上面开发自己的业务。
Server不会消失,而是让一般的开发者不需要再关注 Server,这意味着【智能弹性】、【快速交付】、【更低成本】,这也是 Serverless 相关产品的典型特性。
所以没必要再去给 Serverless 做什么定义,他本身已经描述的很清晰。我们抛开概念,具体看看在各个具体技术领域的产品,相信你会有更直观的认识。
三、PaaS在 Serverless 时代的重生
PaaS 本身的概念挺大,广义的说它处于IaaS和SaaS之间,我们先从一个具体的产品说起:GAE(Google App Engine)。2006年AWS推出了IaaS的云计算,Google认为云计算不应该是IaaS这样的底层形态,所以在2008年推出了自己的云计算代表产品GAE(关于这里的发展缘由,可以参考张磊的这篇文章:容器十年 ,一部软件交付编年史)。
初推出的GAE,也像Lambda,让人眼前一亮,但是很快开发者就发现它的限制非常多,用今天的话说就是典型的“我不要你觉得,我要我觉得”,最后的结果就是大家都纷纷回到了IaaS的怀抱。

到后来的PaaS产品比如Cloud Foundry,这类PaaS产品相对更实际一些,底层IaaS还是云厂商提供,上层提供一套应用管理生态,背后的思想还是不希望开发者通过IaaS这么底层的方式去使用云计算,而是从PaaS开始,不过它也不是Serverless化的,你还是要考虑服务器的维护、更新、扩展和容量规划等等。
SAE(Serverless App Engine)
到了现在,随着容器技术的成熟,以及Serverless理念的进一步发展,PaaS和Serverless理念也开始融合,这样的产品既有PaaS为代表的【快速交付】,又有Serverless的特点【智能弹性】、【更低成本】,典型的产品代表就是阿里云在2019年推出的产品:SAE(Serverless App Engine)。
首先,它是一个PaaS,再具体一点说,是一个应用PaaS。这意味着大部分开发者使用起来都会非常自然,因为里面的概念你会非常熟悉,比如应用发布、重启、灰度、环境变量、配置管理等等。
同时,它也是Serverless化的。这意味着你不必再关心服务器,不用再申请机器,维护服务器,装一堆工具,而是按需使用,按分钟计费,结合强大的弹性能力(定时弹性、指标弹性)实现极致成本。
最后,得益于Docker为代表的容器技术的发展,SAE解决了经典PaaS的突出问题(各种限制和强绑定),依托于容器镜像,在上面可以跑任意的语言的应用
看到这里,我相信大部分开发者对于 PaaS 和 Serverless 结合的产品已经有了一个轮廓,在中国云原生用户调研报告中(2020年) ,这种形态的Serverless产品开始被越来越多的开发者采用。

在这个基础上,还有另外一个话题值得再讨论一下,那就是微服务和 Serverless。
微服务和 Serverless
现在业界关于微服务和 Serverless,会有部分这样的认知:认为当前云计算典型代表技术是微服务,下一代的代表技术是 Serverless,这会让你 Serverless 比微服务要先进,甚至会觉得未来有了 Serverless 就没有微服务了,类似下面这张图:

个人认为产生这一认知还是因为将 Serverless 的理念具象化到函数计算(FaaS)这样的产品。现在我们聊到微服务,会想到背后的技术框架,比如Spring Cloud、Dubbo,但是其实微服务这个词已经远远超出了纯技术框架的范畴,他背后也有核心的支撑思想,包括:
1 . 微服务虽然一定程度上增加了技术复杂度,但是在一定规模下他会降低系统复杂度和组织复杂度。
2 . 现代业务系统越来越复杂,很多业务系统会基于领域驱动设计(DDD)设计,微服务其实是DDD背后的支撑技术。

所以如果到了Serverless时代就没法用微服务,我相信很多开发者会觉得不知所措,或者会“抵触未来”,因为他们会觉得有人给我描绘了一个未来,但是完全不知道怎么走过去。
抛开各种具体的技术实现,回到背后的理念,Serverless代表的是一种无需关注服务器,降低使用云计算服务的理念,所以它和微服务其实不冲突,完全可以共存。在阿里云的SAE中,集成了微服务的能力(依托于阿里云产品MSE),这意味着:
1 . 部署在SAE这类Serverless平台上的应用,完全可以继续使用微服务开发,不需要经过任何改造。
2 . 在SAE上甚至提供了很多微服务能力增强,包括了注册中心托管、服务治理等等,进一步降低开发者使用微服务的门槛和负担。

所以在Serverless类的PaaS产品上,Serverless和微服务不再是对立的,开发者完全可以继续使用微服务技术开发,同时也可以享受Serverless理念所带来的【智能弹性】、【更低成本】等。
四、函数计算FC
讲完Serverless Application(应用),我们再来看看Serverless Function(函数),FC作为”根正苗红“的Serverless产品,相信大家都对他不陌生,经过这么些年的发展,它已经在前端Serverless、多媒体处理、AI、事件类的场景(云产品事件、数据库变更事件等等)、物联网消息等场景得到了很好的应用,甚至也有越来越多的公司将业务完全构建在FC之上,比如:世纪联华的 Serverless 实践。
另外针对早期的很多技术限制,现在也已经有了解决方案:
1 . 早期大多数的函数计算产品都对磁盘大小、代码包大小、运行时长、内存规格等有限制,阿里云函数计算推出了性能实例基本解决了这些限制。
2 . 针对冷启动问题,可以使用预留性能实例解决。
下面我们就具体介绍部分使用FC的典型的场景
前端Serverless
前端经过了Ajax、Nodejs、React等技术迭代后,已经形成了相对成熟的技术体系,特别是Nodejs,使前端和服务端产生了联系。
前端和后端的分工发挥了各个的优点,但是在协作的过程中也一直存在一个问题,后端同学通常是面向领域和服务提供接口,但是前端是面向用户具体的数据接口,有时候一个简单的需求会因为两边的定义和联调搞半天。所以也诞生了BFF(Backends For Frontends)这样一层,谁使用谁开发,专门解决领域模型 - UI 模型的转换。

理想很美好,现实也很骨干,如果前端同学去做BFF这一层,发现要学习后端的DevOps、高可用、容量规划等等,这些其实是前端同学不想关心的,这种诉求在Serverless时代得到了很好的解决,由BFF变为了SFF(Serverless For Frontend),让前端同学只要写几个 Function,其他都交给Serverless平台
类似的还有服务端渲染 SSR(Server Side Rendering),本来前后端分工后,后端只需要写接口,前端负责渲染,但是在SEO友好以及快速首屏渲染等需求背景下,有时候会用到服务端渲染的方案,同样,使用Serverless 前端同学又可以愉快的玩耍了。
其实现在很多偏前端产品里面(比如各类小程序以及语雀等产品),前端同学会全栈完成整体开发,越来越多的会用到Serverless相关技术
当然,要用好Serverless,需要完整的生态,包括相关的框架,运行时,工具链,配置规范等等,这方面可以参考阿里 Midway
多媒体处理
现在在线教育、直播、短视频等等行业都蓬勃发展,也催生了很多视频需求,包括视频的处理,包括视频剪辑、切分、组合、转码、分辨率调整、客户端适配等等,典型场景的比如:
每周五定期产生几百个 4G 以上的 1080P 大视频, 但是希望当天几个小时后全部处理完
甚至您有更高级的自定义处理需求,比如视频转码完成后, 需要记录转码详情到数据库, 或者在转码完成后, 自动将热度很高的视频预热到 CDN 上, 从而缓解源站压力。
这些诉求在Serverfull的场景下,你可能需要搭建一套复杂的系统来支撑,但是如果使用FC那么你会发现一切都变得那么简单。

AI Serverless
AI Model Serving 是函数计算一个比较典型的应用场景。数据科学家训练好模型以后往往需要找软件工程师把模型变成系统或者服务,通常把这个过程称之为 Model Serving。函数计算无需运维和弹性伸缩的特性,正好符合数据科学家对高可用分布式系统的诉求。
五、Serverless容器-ASK
Kubernetes作为生产级别的容器编排系统,现在已经成为了容器编排的事实标准,被广泛用于自动部署,扩展和管理容器化应用。它也有相应的Serverless Kubernetes产品,比如阿里云的ASK、AWS Fargate等。在这类产品中,你无需购买节点即可直接部署容器应用,无需对集群进行节点维护和容量规划,并且根据应用配置的CPU和内存资源量进行按需付费。ASK集群提供完善的 Kubernetes 兼容能力,同时降低了 Kubernetes 使用门槛,让您更专注于应用程序,而不是管理底层基础设施。
如果您是K8S的重度用户,那么使用Serverless Kubernetes是一个不错的选择,典型客户场景包括:
微博:在30s之内可以极速扩容500个应用实例,应对跨年活动和热点事件;
旷视科技:基于ASK开发智能、免运维的AI应用平台;
趣头条:基于ASK构建Serverless大数据计算平台。
六、BaaS
上面提到的都是”计算类“Serverless产品,FC、SAE、ASK等,但是我们都知道,开发过程中不可能只有计算逻辑,还有很多其他依赖,比如存储、中间件等。BaaS(Backend-as-a-Service,后端即服务)类产品,提供基于API的服务,这些API一般都是按需使用、免运维、自动扩缩容的,所以他们也是Serverless的。
典型的比如阿里云的OSS,具有与平台无关的 RESTful API 接口,可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。
值得一提还有开发企业级应用时大家非常熟悉的中间件,以阿里为例当前也在进行4.0技术架构升级,全面BaaS化,统一运维、交付、计费、支持模式,开箱即用,产品化程度持续提升
七、总结
总结一下,上面提到的一系列Serverless的产品,覆盖了前端,后端,容器,BaaS各个领域,包括很多上面没有提到的(比如CDN)其实也算是Serverless的产品,所以我不认同伯克利的Serverless=BaaS+FaaS的观点,但是我非常认可他的另一个观点:“Serverless will dominate cloud computing”。
Serverless首先是一个理念,不是某一种具体的技术,当未来某一天,99%的云产品都有Serverless化的形态时,云计算也就Serverless化了,这种变化我认为不是非黑即白的,不是推翻重来这种革命性的,而是全面的降低用户使用云的成本,全面的提升开发者的研发效率。
作者简介:陈涛,10年软件开发经验,4年创业经历,曾在淘宝、滴滴任职,关注云原生、微服务、Serverless 等技术领域,积累了在云计算、电商、从0到1创业等方面的研发、管理和业务经验。目前就职阿里云,在云原生应用平台从事Serverless应用引擎(SAE)的设计和研发。
6岁!是时候重新认识下Serverless了的更多相关文章
- 只是想虐下春丽,一不当心玩了下serverless...感觉还不错哟!
事情是这样的-- 前天下午天太热,我在家看电视,换台突然就看到了正在播<西游记>,窗外蝉声特别响,我一下就有种穿越回小学暑假的感觉.当时,我就特别想把我那台小霸王翻出来,玩两盘街霸--虐一 ...
- Serverless架构详解:开发者如何专注于业务代码本身?
本文来自腾讯云技术沙龙,本次沙龙主题为Serverless架构开发与SCF部署实践 演讲嘉宾:黄文俊,曾负责企业级存储.企业级容器平台等产品的架构与开发,目前主要负责SCF腾讯无服务器云函数产品相关. ...
- Response to 16岁的篮球投手
关于篮球,我想写的很多,被偏爱的运动,被赞美的运动,带着青春的万丈光泽. 我们对易建联的苛刻是因为想当然,对大侄子的溺爱是因为急功近利.过于娱乐化和商业化,让一项竞技体育变得像是豆瓣八组的吃瓜盛宴. ...
- 基于 Serverless Component 全栈解决方案
什么是 Serverless Component Serverless Component 是 Serverless Framework 的,支持多个云资源编排和组织的场景化解决方案. Serverl ...
- 基于 Serverless Component 全栈解决方案 Ⅱ
虽然之前的文章 基于 Serverless Component 的全栈解决方案 介绍了如何借助 Serverless Component 快速搭建 Restful API 后端服务 和 Vue.js ...
- Serverless + Egg.js 后台管理系统实战
本文将介绍如何基于 Egg.js 和 Serverless 实现一个后台管理系统 作为一名前端开发者,在选择 Nodejs 后端服务框架时,第一时间会想到 Egg.js,不得不说 Egg.js 是一个 ...
- 如何开发自己的第一个 Serverless Component
前言 上一篇 基于 Serverless Component 的全栈解决方案 介绍 Serverless Component 是什么和如何使用 Serverless Component 开发一个全栈应 ...
- Serverless 基本概念入门
从行业趋势看,Serverless 是云计算必经的一场革命 2019 年,Serverless 被 Gartner 称为最有潜力的云计算技术发展方向,并被赋予是必然性的发展趋势.Serverless ...
- 五分钟快速搭建 Serverless 免费邮件服务
1. 引言 本文将带你快速基于 Azure Function 和 SendGrid 构建一个免费的Serverless(无服务器)的邮件发送服务,让你感受下Serverless的强大之处. 该服务可以 ...
随机推荐
- 面试必备:排序算法汇总(c++实现)
排序算法主要考点: 7种排序 冒泡排序.选择排序.插入排序.shell排序.堆排序.快速排序.归并排序 以上排序算法是面试官经常会问到的算法,至于其他排序比如基数排序等等,这里不列举. 以下算法通过c ...
- java交互Scanner类
用next方法接收 import java.util.Scanner; public class Demo01 { public static void main(String[] args) { / ...
- 剑指offer计划5(查找算法中等版)---java
1.1.题目1 剑指 Offer 04. 二维数组中的查找 1.2.解法 其实就是暴力解法的升级版,从最后一行开始判断,通过num当前的大小, 如果还是大于目标值则行数-1,若是小于则列数+1 1.3 ...
- multipass指定virualbox搭建k8s集群(选择docker作为默认容器)
目录 前言 步骤 初始化三台虚拟机 统一安装docker 修改docker镜像源 查看masterIP 安装master节点(重点设置) 查看master的token 安装worker节点 测试 部署 ...
- 致敬mentohust,路由器使用Socket认证华科校园网
致敬mentohust,路由器使用Socket认证华科校园网 前言: 上一篇文章中,为了解决ESP32华科无线网认证的问题,我成功把网页认证机制用Python+Socket复现.但痛点依然存在,无线网 ...
- Linux - yum 安装软件时被 PackageKit 锁定
问题描述 yum 安装软件的时候报错 sudo yum install netease-cloud-music 已加载插件:fastestmirror, langpacks /var/run/yum. ...
- Selenium自动化实现web自动化-1
框架搭建 基于maven+jdk8+junit5+seleium 构建 <dependencies> <dependency> <groupId>org.junit ...
- vue 动态ip配置,避免重复打包
目前比较流行的打包大都是在vue.config.js配置代理,然后在根目录新建.env.xxx文件配置正式环境,测试环境,开发环境等用于打包时配置不同的访问地址,作为一名随波逐流的前端开发,我也是这么 ...
- 方法重载(Override)
什么是方法的重写(override 或 overwrite)? 子类继承父类以后,可以对父类中同名同参数的方法,进行覆盖操作. 应用: 重写以后,当创建子类对象以后,通过子类对象调用子父类中的同名同参 ...
- Alibaba《Java开发手册》之Java代码规范笔记
前言 一种工具被发明出来,那么针对这种工具的各种使用规则.条条框框就随之而来.无规矩不成方圆,无制度则无国家,无风格不成代码!治国有国法.排兵布阵有章法.那么写代码也有它界内通用的不成俗的约定.最近刚 ...