写点什么

何时该用无服务器,何时该用 Kubernetes?

  • 2019-01-10
  • 本文字数:1368 字

    阅读完需:约 4 分钟

何时该用无服务器,何时该用Kubernetes?

什么时候该用无服务器,什么时候该用 Kubernetes 构建云原生应用程序?


一个好的无服务器应用场景应该是在夜间没有太多或者完全没有流量。由于无服务器平台仅在代码运行期间收费,因此可以显著降低成本。较大的应用程序不执行任何操作,无服务器便宜的可能性越大。


但是,这并不意味着无服务器就可以降低成本,如果应用程序全天候运行,可能存在一些隐性成本,比如管理 API 造成的额外成本和测试函数的调用成本。

没经验,怎么选?

就听而言,无服务器和 Kubernetes 好像已经非常成熟;但就实践而言,二者还有很多成长空间,研发人员也并未达到人人普及的程度。如果既没有无服务器也没有 Kubernetes 经验,那么,在无服务器平台运行 Hello World 应用程序应该更容易。


因为无服务器只需将精力集中在代码上即可,使用 Kubernetes 则通常需要等待一段时间来创建集群,配置 Kubernetes 以获取公共 IP 地址,然后再部署容器。使用无服务器平台,只需使用云提供商的 Web 工具即可在几分钟内上手。

有经验,怎么看?

这种难易程度也是变化的,无服务器并不总比 Kubernetes 更容易。使用一堆函数构建和管理无服务器应用程序比只有一个容器的简单 Kubernetes 应用程序更难。实际上,将 Kubernetes 用于更复杂的应用程序可能更容易,因为该平台更成熟。


无服务器计算最强大的功能之一是自动可扩展性,开发人员无需采取任何措施就可利用此功能。使用 Kubernetes,研发人员还可使用 pod 甚至节点自动可扩展性,但需要一些配置并且速度稍慢,因为只有在某些规则适用时才会触发此过程。


但是,Kubernetes 可能提供比某些无服务器平台更好的可扩展性,因为 Kubernetes 更加成熟,并且在不同区域之间提供 HA(高可用性),这并非所有无服务器平台都提供。


A/B 测试可能是构建云原生应用程序的关键功能,但无服务器平台并不具备这一点,Kubernetes 则可以。此外,Kubernetes 应用程序的监控功能更加成熟。例如,使用 Istio 可以看到微服务的执行时间,服务调用情况以及是否存在问题。无服务器平台因其自身的最大优势就是不需要操心基础设施,所以研发人员可做的操作也十分有限。


如果应用程序相当简单,只有一个函数提供 API,则无服务器可能是更好的选择,因为部署会更容易,并且各种无服务器平台都可提供对单个函数的监控。

响应延迟对比

使用无服务器平台时,由于需要初始化代码,因此第一次调用函数需要花费一些时间。比如,在 OpenWhisk 中使用 Docker 容器,容器需要时间才能启动 Java 应用程序。如果需要快速可靠的响应时间,则可以使用 Kubernetes。


通过应用缓存,无服务器平台对响应时间做了改善。第一次冷启动后,不必再花费较长响应时间启动第二次,这可能足以满足应用需求。

高性能计算对比

无服务器平台通常具有某些资源限制,比如,功能不能超过 512 MB 的 RAM,不能超过 5 分钟。如果这些限制对应用程序来说过于严格,则需要使用 Kubernetes。有时也会在较小的功能中分解应用程序,比如,将现有单片应用程序移到云中。

结语

无服务器计算和 Kubernetes 对应不同的应用场景,也有着各自的缺点。如果是初学者,建议从无服务器计算开始,毕竟 Kubernetes 的配置过程相对繁琐。如果是企业用户,追求高性能计算、更优性能并希望运行大规模应用程序,Kubernetes 依旧是最佳选择。


参考链接:https://dzone.com/articles/when-to-use-serverless-when-to-use-kubernetes


2019-01-10 13:218686
用户头像
赵钰莹 极客邦科技 总编辑

发布了 883 篇内容, 共 648.5 次阅读, 收获喜欢 2680 次。

关注

评论

发布
暂无评论
发现更多内容

若依集成 WebSocket,linux学习步骤

Java 程序员 后端

蓦然回首,十余年的程序员生涯最后就只剩下了这些!希望我犯过的错误你不要再犯

Java 程序员 后端

蘑菇街Java大牛纯手打肛出的一份多线程文档,请别丢进收藏夹吃灰

Java 程序员 后端

腾讯T4:结合我多年工作经验给程序员的几点忠告,别再埋头苦干了

Java 程序员 后端

蘑菇街大牛熬夜整理的Java多线程知识点总结(思维导图+源码笔记

Java 程序员 后端

蚂蚁金服+拼多多+抖音,java从入门到精通第四版视频

Java 程序员 后端

蚂蚁金服二面被血虐,spring-并发-JVM把我直接问懵,我经历了什么-

Java 程序员 后端

膜拜!京东T9大牛沉淀三年终于整理出了这份架构核心修炼之道

Java 程序员 后端

腾讯T4架构师:刷3遍以下面试题,你也能从小公司成功跳到大厂

Java 程序员 后端

蚂蚁金服Java开发岗面试挂了以后,流泪总结了这份大厂常问面试题!

Java 程序员 后端

血赚!阿里P9整理出内部500多页最全双十一顶级秒杀方案笔记

Java 程序员 后端

聊聊多线程(四)线程安全之AtomicInteger类,最全面试考点与面试技巧

Java 程序员 后端

架构实战营- 模块二作业

危险游戏

架构实战营

腾讯五面、快手三面已拿offer(Java岗位,linux基础教程第二版pdf

Java 程序员 后端

腾讯技术大牛带你玩转Spring全家桶,赠三本Spring实战篇电子文档

Java 程序员 后端

被 boss 直聘转发过多而“封杀”的 2021 年全套 高级面试题有多牛

Java 程序员 后端

肝完这份Linux网络编程笔记,感觉2年开发白干了,nginx反向代理原理转发过程

Java 程序员 后端

脉脉上瞬间爆火的Java高级面试题被全网封杀,这套资源到底有什么魅力?

程序员 后端

腾讯T8纯手写66个微服务架构设计模式,全部学会真的“变强

Java 程序员 后端

腾讯、美团等六家大厂收到offer,浅谈大数据面试经历,2021Java面经

Java 程序员 后端

获12w+星标的神仙文档再度上榜,简直是一套活生生自学Java的福星

Java 程序员 后端

蚂蚁金服面试经验分享,阿里的offer真的不难,初面蚂蚁金服

Java 程序员 后端

聚焦WAVE SUMMIT 2021,大咖齐聚共研深度学习(1),java在大数据技术中的运用

Java 程序员 后端

脑筋急转弯:如何用两个栈实现一个队列?用两个队列实现一个栈

Java 程序员 后端

膜拜!华为内部都在强推的783页大数据处理系统:Hadoop源代码pdf

Java 程序员 后端

自己搭建电商平台初期,原来“超卖,java书籍百度网盘

Java 程序员 后端

被Netty搞昏了头,先学一下幂等性压压惊吧,java程序员面试宝典pdf

Java 程序员 后端

脑筋急转弯:如何用两个栈实现一个队列?用两个队列实现一个栈(1)

Java 程序员 后端

腾讯启动有史以来最大校招:苦逼程序猿,拿头发换了高质量生活

Java 程序员 后端

被Netty搞昏了头,先学一下幂等性压压惊吧(1),只需一篇文章吃透Java多线程技术

Java 程序员 后端

聚焦WAVE SUMMIT 2021,大咖齐聚共研深度学习,关于线程池的五种实现方式

Java 程序员 后端

何时该用无服务器,何时该用Kubernetes?_服务革新_赵钰莹_InfoQ精选文章