文档章节

Bazaar:阿里云Serverless计算服务探秘

阿里云云栖号
 阿里云云栖号
发布于 2018/06/08 15:30
字数 2005
阅读 134
收藏 0

摘要: Serverless 指用户无需管理服务器情况下构建和运行应用程序的一种方式。可见 Serverless 并不是真的不需要服务器,毕竟程序代码不能靠意念来执行,仍然是需要硬件服务器实体来作为运行代码的基础的。

Bazaar:阿里云Serverless计算服务探秘

 作者:Bazaar项目组

1.     什么是 Serverless

“Serverless computing refers to the concept of building and running applications that do not require server management.”

-- 来自 CNCF 对 Serverless 的定义

Serverless 指用户无需管理服务器情况下构建和运行应用程序的一种方式。可见 Serverless 并不是真的不需要服务器,毕竟程序代码不能靠意念来执行,仍然是需要硬件服务器实体来作为运行代码的基础的。这里的 Serverless 是站在应用开发人员的视角提出的,指服务器的运行、维护对于应用程序的开发人员不可见。将底层基础架构的维护、更新和扩展等任务交给平台提供商来完成。从而将业务开发人员解放出来,让他们更好的关注自身业务。这便是 Serverless 计算背后的核心思想。可见这一思想能够产生的一大基石便是云计算服务。只有凭借云计算构建的强大基础运维平台,才能够适应无服务器计算对于计算、存储和网络资源的需求。

图1展示了 Serverless 计算的发展历程。早在2006年就已经出现了第一个带有 Serverless 性质的计算服务平台 Zimki,该平台会按照代码实际执行时间向用户收取相应的费用。随后的2008年谷歌推出Google App Engine产品,其背后的理念也是 Serverless 计算。但这一时期,Serverless 计算的概念并没有被明确提出。Serverless 概念第一次出现的时间是在2012年,iron.io,一家基于容器提供分布式按需执行服务的提供商提出了这一概念。2014年AWS Lambda这一里程碑式的产品出现。通过将无服务器计算的概念嵌入到整个云计算服务的整体框架中,无服务器计算正式走进了云计算的舞台中央。2016年无服务器计算则迎来了快速发展的阶段,IBM、谷歌、微软相继推出了IBM OpenWhisk on Bluemix、Google Cloud Functions和Azure Functions等相关产品。而到了2018年,随着容器技术的发展,各类 Serverless container 平台更是如雨后春笋般出现在人们的视线中。

 

图1  Serverless 发展历程

对于 Serverless 带来的好处可以归结于以下几点:

·      *降低成本

·      *灵活扩容

·      *按需付费

降低成本:使用 Serverless 服务后,用户不再需要关心采购、运行、维护底层机器资源的相关工作,也不再需要对相关工作投入人力资源。特别是机器运维的成本将大幅下降。

灵活扩容:用户自己购买服务器对外提供服务时,当业务压力突然增加时,很难快速添置大量服务器来满足突增的业务压力的需要。而采用无服务器计算后平台提供商会有大量机器资源供用户动态扩容使用。

按需付费:用户自己购买服务器时,即便业务负载非常低,用户依然要负担相关资源的使用成本。极端情况当用户业务负载压力为零时,用户也要白白花费相应的成本来维持自身服务的运转。在使用无服务器计算后,当用户业务压力降低时,用户需要的资源会被自动减小,因而花费的成本也自然会降低。

总之 Serverless 让开发人员更加聚焦于自己业务的同时,更可以有效帮助企业降低业务运行过程中不必要的开销和成本。

Serverless 中非常重要的一个环节是底层相关计算资源的管理不再需要用户来关心,那么这些资源的管理由谁来完成呢?下面我们就来介绍本系列文章的主角——Bazaar。

2.     Bazaar:阿里云 Serverless 计算服务

Bazaar ([bə'zɑːr])是阿里云弹性计算团队为孵化更多的 Serverless 服务推出的基础服务。该服务旨在为终端用户和云上的各类 Serverless 产品提供底层的资源管理、交付服务。无论是终端用户还是阿里云的各类 Serverless 产品亦或是外部的Serverless服务开发商均可以借助Bazaar方便的获得需要的云计算资源。凭借弹性计算团队和容器服务团队在云计算服务领域积累的丰富经验,我们将Bazaar打造成为一款面向不同客户和业务的资源交付服务以便支撑各类无服务器计算业务对底层云计算资源管理、交付的不同诉求 。

Bazaar具备 Serverless 带来的诸多优点。如用户聚焦自身业务,简化底层资源管理,灵活的扩容方式等等。相较于弹性计算ECS,Bazaar在资源占用开销、实例启动时间等方面也着重进行了优化,并从系统整体架构上针对 Serverless 进行了深度的定制优化。

Serverless 通过平台服务商管理底层运行时环境,为用户摆脱底层基础架构运维工作提供了可能。而平台服务商为了向用户提供这样一个统一的计算平台,势必需要一个统一的底层软件运行环境。在这其中的沙箱技术就是最为核心的技术组件,其要为用户程序的运行提供一个安全且与外界隔离的环境。该环境还必须考虑到 Serverless 自身的特点,在应用部署密度,程序启动时间等方面做出相应的优化,来满足无服务器计算高并发,用户负载不稳定的需要。

由于Bazaar要兼容Docker/Kubernetes生态,并提供安全、多租户等公有云需要的特性,对于当前Serverless产品来讲,最为适合的容器技术架构依然是通过硬件虚拟化来作为Bazaar安全容器的底层技术。考虑到Serverless用户的特定场景和需求,我们在传统虚拟机上又进行了进一步的改进和优化。比如禁用了登录服务器,添加/删除用户功能,同时精简了不必要的系统服务。

图2中展示了我们在Bazaar针对 Serverless 场景在底层系统上进行的各类优化。

 

图2  Bazaar底层系统优化

通过上面的各种优化,Bazaar实例的启动时间相较于此前ECS实例有了显著的提升,如图3所示。

 

图3  优化前后启动时间对比

3.     展望

可以看到随着容器技术的快速发展和 Serverless 计算产品的普及,以虚拟机为代表的第一代云计算服务(IaaS)正在逐渐让位给以 Serverless 为代表的新一代云计算服务。而这一趋势对底层系统软件的开发也提出了更高的要求。新一代底层系统软件不仅要满足安全、隔离、多租户的需求,更要针对 Serverless 的特点进行整体端到端优化。相信随着 Serverless 的不断发展,会诞生更加优秀的系统来支持 Serverless,为用户提供更好的下一代云计算服务。

原文链接

本文为云栖社区原创内容,未经允许不得转载。

© 著作权归作者所有

阿里云云栖号
粉丝 462
博文 1558
码字总数 3823668
作品 0
朝阳
私信 提问
加载中

评论(0)

Bazaar:阿里云Serverless计算服务探秘

Bazaar:阿里云Serverless计算服务探秘 作者:Bazaar项目组 1. 什么是 Serverless “Serverless computing refers to the concept of building and running applications that do not requi......

云上未来
2018/05/30
0
0
阿里云开发者Workshop实战营

阿里云开发者Workshop实战营 这是一场专门针对开发者、架构师,产品技术管理人员的实战之旅。在这里将有 阿里云MVP最有价值专家,阿里云技术专家分享 微服务,Serverless,开发者工具,数据库...

pfytlm
2018/12/17
208
0
阿里云E-HPC联合安世亚太、联科集团共建云超算生态

摘要: 进入“中国制造2025”新时代的节奏又加快了速度!阿里云是国内最大的云计算厂商,去年9月阿里云推出了首个公共云上的超算平台,可一键部署获得媲美大型超算集群环境的云上超算中心,在...

阿里云云栖社区
2018/05/28
27
0
云栖大会·武汉峰会|安世亚太宣布基于阿里云EHPC能力推出国内首个高性能仿真云平台PERA.SimCloud

5月23日,2018云栖大会武汉峰会,阿里云高级技术专家刘峥和张维,对弹性计算最新上线的 serverless (无服务器化)计算技术Bazaar及基于该技术的容器服务产品 Severless Kubernetes 进行了解...

云上未来
2018/05/25
0
0
[武汉峰会]IT人必看!2018年上半年云栖大会300份干货免费开放!— 武汉峰会

最前沿的技术都在这了! 武汉峰会 5.23 2018阿里云栖大会武汉峰会于5月23日在光谷希尔顿酒店举行。大会以“驱动数字中国”为主题,聚焦IoT、智能制造、新零售等行业,描绘新技术发展趋势和蓝...

迷你芊宝宝
2018/06/28
14
1

没有更多内容

加载失败,请刷新页面

加载更多

【 开发指南 】智能家居技能

本文作者:DuerOs 目录 一、教学视频 二、整体架构 三、开发步骤&资料整理 四、常见问题解答 五、智能家居文档 树状提纲 ————————————————————————————————...

百度开发者中心
2019/03/29
23
0
008. 并发容器类 Map

1. JDK 源码学习方法 1. 演绎推导法 示例:因果推理。 因为 JAVA 中只提供了 BIO 和 NIO 两种方式,所以一切框架中,涉及到网络处理的,都可以用这两个知识点去探究原理。 2. 归纳总结法 示例...

紫穹
今天
75
0
如何使用sed替换换行符(\\ n)? - How can I replace a newline (\n) using sed?

问题: How can I replace a newline (" \\n ") with a space (" 如何将换行符(“ \\n ”)替换为空格(“ ") using the sed command? “)使用sed命令? I unsuccessfully tried: 我尝试失......

javail
今天
115
0
OSChina 周一乱弹 —— 原来这叫分别焦虑

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: 《A Careful Tearing》- Levi Patel 手机党少年们想听歌,请使劲儿戳(这里) 清明...

小小编辑
今天
184
0
trim、stripslashes、htmlspecialchars函数

通过 PHP 验证表单数据 我们要做的第一件事是通过 PHP 的 htmlspecialchars() 函数传递所有变量。 在我们使用 htmlspecialchars() 函数后,如果用户试图在文本字段中提交以下内容: <script>...

imzchloe
今天
130
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部