Containers vs Serverless:你选择谁,何时选择?
两者都是当今技术时代的热门话题,也都被视为是开发技术的竞争对手。
首先,还有相当多的好奇和担心。此外,两者都是可供工程师使用的、高效的、机器无关的抽象。
但是,在冠军之间,有一个不可逾越的鸿沟。你要么在容器区域,要么选择 Serverless。除此之外,如果你愿意将两者结合起来,那将是一个强大的组合。
预计到 2021 年,Serverless 将达到 77.2 亿美元 的规模。但对容器的需求也将增长 40%。
1. 什么是 Serverless?
简而言之,Serverless 是运行在服务器上的,基于云服务的子集。
1.1. 容器 vs. Serverless:为什么 Serverless 更好?
服务提供商或供应商管理 Serverless 操作的基础设施需求。你所需要做的就是部署代码。因此,你有机会更专注于应用逻辑,而不必担心基础设施。
该技术在主流企业中是非常酷的一种存在。

来源:https://www.slideshare.net/speckandtech/a-bot-in-minutes-with-serverless
有很多可用的平台 —— Google 云、AWS Lambda、EdgeEngine
2. 为什么要从 Containers 到 Serverless?
2.1. 廉价
使用 Serverless,你通常是按使用量付费。闲置资源会有价格豁免。例如,Lambda 以 100 毫秒范围为其计时单位。
此外,由于任务很小,且运行在较小的 Serverless 功能上,因此开销成本可达到最小化。
2.2. 低维护
除此之外,代码部署、容器配置、系统策略、可用性级别或后端服务器任务,都不再是你头疼的问题。
你有机会试用自动扩缩容。
2.3. 原型简单

来源:epsagon.com
在主机应用环境下,Serverless 是一种外部集成。因此,个人容器的生命周期可以避开任何运行时故障的情况。
3. 使用 Serverless 的场合有哪些?
3.1. 网站或应用的后台任务
像其他服务器一样,Serverless 接受来自数据库或前端程序及站点的信息。根据程序来检索数据并将其返回给用户接口。
与容器相比,Serverless 的定价差异在于,其计费取决于实际的后端任务执行持续时间。
3.2. 大容量后台进程
在销售系统上,Serverless 功能可组织库存和交易数据库以及重新进货等临时任务。
最后但同样重要的是,Serverless 在将数据转换为持久化存储或将指标转发给分析服务方面是非常方便的。
4. Serverless 的限制
这些限制发生在大小和内存使用方面,或者说是基于 Serverless 架构的限制。
例如,为了保持函数的正常运行,并防止额外的系统资源消耗,本机支持的编程语言的有限列表对于 Serverless 来说并不自然。由于基本功能的限制,Serverless 函数可能并不适合监控工具。首先,Serverless 是对主框架平台的外部集成支持。
因此,你无法访问内容管理系统。
5. 什么是容器微服务?

这只是 独立包 的一部分,在其中部署、执行和扩展了一个应用程序。
根据 亚马逊 的介绍,容器是“一种操作系统虚拟化的方法,其允许用户在资源隔离的进程中运行应用程序。”
根据容器框架,Docker 的说法,容器管理平台声明:“容器是一个软件单元,它将代码及其所有依赖打包在一起,因此应用程序可以快速可靠地从一个环境迁移到另一个环境。”
在从一个环境到另一个环境的迁移过程中,容器概念非常有用。原因在于其能够在迁移期间引入隔离,以避免任何变量的改变。
因此,如果你要将设计的产品代码从开发迁移到生产,这将是为你而准备的。
6. 容器 vs. Serverless:为什么选择容器?
其优点很多。
6.1. 容器 vs. Serverless:容器助力大型化项目

如果你有这方面的技术专长,那么你会喜欢使用容器。它最适合更为广泛的应用或企业。在这种情况下,使用 Serverless,你可能很快就会面临代码蔓延而难以管理的问题。
例如,如果在 Serverless 应用上运行,则折射器会出现各种瓶颈。结果将是极其分散的微服务。
6.2. 容器 vs. Serverless:完全控制 Docker
你可以设置策略、保留和管理资源、严格控制安全性,并充分利用容器来管理和迁移服务。
基础架构命令全都掌握在你手里,只需按需定制即可。
6.3. 容器 vs. Serverless:调试、测试及监控
手动浏览容器活动的开关及状态。
这就确保了有效深入的调试和测试、对资源的全方位使用,以及在各个级别进行深入的性能监控。
7. 容器的好处在哪里?
第一个也是最重要的好处是“特有的易移植性”。你可以将所有应用程序与所有依赖组合在一个小的 package 中并在任何地方运行它。
容器非常适合大型应用程序,因为其不受内存或大小限制。你是这里所有涉及功能的唯一所有者。
8. 对比容器 vs. 无服务运算
如果要对比容器与 Serverless 计算之间的区别。
容器最适合大型和复杂的应用。 如果您的产品对环境敏感,则需要一丝不苟的质量保证和监控,容器是解决方案。
容器在迁移遗留的单体应用时也很方便。 您可以将此大型应用程序碎片整理为容器,并使用第三方工具进行安装。
容器适用于大型电商网站。那种具有相当大的站点地图或者有很多子域的网站。您可以使用容器将每个节点包装在其中。
因此,如果您要开始一个新项目,且产品不需要太多迁移时,Serverless 是最好的选择。例如,Serverless 是物联网(IoT)应用程序的最佳选择。该应用程序监测到水的存在,以识别储水设施的泄漏。
通常,程序不必一直运行,但当泄露的情况下,其需要准备好执行。
通常,当开发速度和成本最小化非常重要,且不想管理可扩展性时,Serverless 是理想的选择。
9. 混合模型

您是否仍然坚持在容器与 Serverless 之间进行选择?
截至目前,两者都可用于相同的开发项目,但用途不同。 Serverless 适用于处理数据事件驱动的触发器。另一方面,容器在技术规范上提供更大的可扩展性和独立性。
有了适当的专业知识,您可以通过容器管理项目的小碎片,作为在 Serverless 上运行项目子集的一种方法。
但这取决于预算管理和项目要求。
结论
容器与无服务器计算?!!正如他们所说,这些是相互竞争的技术!!
基于容器和无服务器的计算是同时代的。 它们支持不断发展的云和基于持续交付的软件世界。 因此,如果您是寻求云战略的人,那么集成技术以减轻弱点对您有利的。
你是哪一方? 你会考虑将两者结合起来吗?
原文:https://geekflare.com/containers-vs-serverless/
译者:万想
9月福利,关注公众号
后台回复:004,领取8月翻译集锦!
往期福利回复:001,002, 003即可领取!

Containers vs Serverless:你选择谁,何时选择?的更多相关文章
- Pandas之容易让人混淆的行选择和列选择
在刚学Pandas时,行选择和列选择非常容易混淆,在这里进行一下讨论和归纳 本文的数据来源:https://github.com/fivethirtyeight/data/tree/master/fa ...
- 选择Android还是选择JavaEE?
很多同学咨询过同样的一个问题,该问题也是最备受争议的问题,那就是到底是选择Android还是选择JavaEE.下面发表一些本人的看法. Android属于一个特有的Java技术应用,专注于 ...
- JS-加载页面的时候自动选择刚才所选择option
<body class="no-skin" onload="option_auto(${pd.PACK_SORT})"> <select na ...
- 选择排序—简单选择排序(Simple Selection Sort)
基本思想: 在要排序的一组数中,选出最小(或者最大)的一个数与第1个位置的数交换:然后在剩下的数当中再找最小(或者最大)的与第2个位置的数交换,依次类推,直到第n-1个元素(倒数第二个数)和第n个元素 ...
- CSS选择符-----元素选择符
通配选择符(*) 选定所有对象 通配选择符(Universal Selector) 通常不建议使用通配选择符,因为它会遍历并命中文档中所有的元素,出于性能考虑,需酌情使用 & ...
- 选择问题(选择数组中第K小的数)
由排序问题可以引申出选择问题,选择问题就是选择并返回数组中第k小的数,如果把数组全部排好序,在返回第k小的数,也能正确返回,但是这无疑做了很多无用功,由上篇博客中提到的快速排序,稍稍修改下就可以以较小 ...
- 选择排序—简单选择排序(Simple Selection Sort)原理以及Java实现
基本思想: 在要排序的一组数中,选出最小(或者最大)的一个数与第1个位置的数交换:然后在剩下的数当中再找最小(或者最大)的与第2个位置的数交换,依次类推,直到第n-1个元素(倒数第二个数)和第n个元素 ...
- jquery操作checkbox方法(全选、全不选、至少选择一个、选择值/文本)
原文:http://blog.csdn.net/u014079773/article/details/52371382 在实际开发中我们经常操作checkbox,不仅仅要获得checkbox选中的值, ...
- project .mpp 查看当天工作任务 1.选择自己 2.选择起始和终止时间 就显示当天的任务了
project .mpp 查看当天工作任务 1.选择自己 2.选择起始和终止时间 就显示当天的任务了
随机推荐
- 从一道没人能答对的面试题聊聊Java的值传递
这是一道我们公司的面试题,从招第二个Java以来就一直存在了.但是面试了这么长的时间还没有一个人可以全部答对,让我们一度以为是这题出的不对.首先请看面试题. 以下运算的输出分别是多少: ```java ...
- 如何运用PHP+REDIS解决负载均衡后的session共享问题
一.为什么要使用Session共享? 稍大一些的网站,通常都会有好几个服务器,每个服务器运行着不同功能的模块,使用不同的二级域名,而一个整体性强的网站,用户系统是统一的,即一套用户名.密码在整个网站的 ...
- 安排:《蚂蚁花呗1234面:Redis+分布式架构+MySQL+linux+红黑树》
前言: 大厂面试机会难得,为了提高面试通关率,建议朋友们在面试前先复盘自己的知识栈,依据掌握程度划分重要.优先级,系统地去学习!如果不准备充分就去参加面试,既会失去进入大厂的机会,更是对自己的不负责. ...
- Delphi - Indy TIdHTTP方式创建程序外壳 - 实现可执行程序的自动升级
Delphi 实现可执行程序的自动升级 准备工作: 1:Delphi调用TIdHTTP方式开发程序,生成程序打包外壳 说明:程序工程命名为ERP_Update 界面布局如下: 代码实现如下: unit ...
- [SNOI2019]字符串
名称:字符串 来源:2019年陕西省选 题目内容 传送门 洛谷(P5392) 题目描述 给出一个长度为$n$的由小写字母组成的字符串$a$,设其中第$i$个字符为$a_i(1≤i≤n)$. 设删掉第$ ...
- [python]变量和赋值
1. python的变量名以字母开头,包含字母.数字.下划线. 2. python是动态类型语言,即不需要预先声明变量的类型.变量的类型和值在赋值的时候被初始化. 变量赋值通过等号来执行. 代码: c ...
- HDU1814Peaceful Commission求2-sa最小字典序
#include <iostream> #include <cstdio> #include <vector> #include <cstring> # ...
- Another Version of Inversion 二维树状数组求逆序对
Another Version of Inversion 题意:只有2种走路方式,往右或者往下,求先走到一个大的数,在走到小的数的这种方式有多少.也就是说求出关于这个2维矩阵的逆序数. 题解:二维数组 ...
- lightoj 1086 - Jogging Trails(状压dp)
题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1086 题解:题目就是求欧拉回路然后怎么判断有欧拉回路只要所有点的度数为偶数.那 ...
- 2017ACM总结
首先对自己表示强烈的谴责, 这个时间应该是打cf的时间, 没有想到我又秀到了自己, 放弃了CF, 23333, 菜鸡wxk. 高中刚毕业的时候,听大学生们跪求老师不要给挂科,当时想的是,哇上了大学就不 ...