认识与设计Serverless(一)
一、什么是Serverless
定义:Serverless是一种无服务器的架构,区别于传统的Baas,SAAS,作为FAAS(函数即服务)而存在,函数由事件驱动触发并按需调用。
按需调用:区别于传统的7x24小时运行的服务,Serverless只会在特定事件触发时运行,并按需收费。
无需关注基础设施和底层资源:虽然称为无服务器的架构,但并不是完全的无服务器,只是人们不再操心运行所需的资源,只需关注自己的业务逻辑,即函数,并且为实际消耗的资源付费,而对于VM,容器和资源(如CPU,内存等资源)则完全交由第三方服务或平台去自动化管理。
二、Serverless特性
(1)降低启动成本:区别传统的服务启动一堆初始化等动作,Serverless只需快速拉取容器部署准备一个函数的资源并启动。
(2)新一代微服务:粒度细化至函数的服务
(3)安全性高:对于虚拟机,容器,网络等资源的安全问题,完全由第三方采用高可靠的方式实现,用户无需关心。
(4)提高开发效率:开发者只需关心自己的函数实现,免去了其他后顾之忧。
(5)拓展性强:Serverless具备的弹性伸缩能力,为函数的自拓展和容灾提供了便利。
三、业界主流产品
(1)AWS :提供一系列完全托管的服务,可以使用它们构建和运行无服务器应用程序。并提供了计算、API网关适配协议,数据库、存储、流处理、消息排队,公共服务等能力
(2)Microsoft Azure:AWS 支持 Serverless 架构一段时间之后,Azure 作为竞品正稳步发展中。除了支持Serverless的众多特性外,Azure 提供快速构建Web端,移动端应用程序,以及实时流数据处理,文件处理和计划任务的自动化,更多内容请参考https://azure.microsoft.com/en-us/services/functions/
(3)OpenWhisk :OpenWhisk 是一个开源项目,具有完整的可视性 FaaS 功能,可扩展也可定制。由于开源可拓展这一特性,自发布以来得到了广大开发者的欢迎,但是目前OpenWhisk的产品和社区还在不断完善中。
四、Serverless弊端
(1)不适合业务逻辑复杂的应用:Serverless比较适合简单,运行时间短的应用或小程序,目前也没有成功的复杂系统的案例。
(2)冷启动时间:函数在执行之前,都需要经过拉取容器,制作镜像并部署的过程,此过程占用函数调用的时间较长。
(3)代码调试困难:目前已有的Serverless云开发平台,都面临一个巨大的问题,即在线debug代码,这是很多云开发平台共同的瓶颈。
(4)CI/CD困难:在应用自动构建,代码自动构建上都有不小的难度。
五、Serverless设计原则
(1)单一责任:函数应尽量保持执行责任单一,尽量少的对众多其他服务或函数形成依赖。
(2)执行时长控制:Serverless是按需执行,按调用次数和时长来收费,所以设计的函数应尽量在毫秒或秒以内,减少递归等,避免造成资金浪费
认识与设计Serverless(一)的更多相关文章
- 认识与设计Serverless(二)
一.设计Serverless的功能模块 第一节讲了Serverless一些概念与特性,废话居多,概念的东西了解过后要有设计与构思,才能学到精髓,一个Serverless平台的形成,涉及到很多模块的架构 ...
- 【转】OpenStack和Docker、ServerLess能不能决定云计算胜负吗?
还记得在十多年前,SaaS鼻祖SalesForce喊出的口号『No Software』吗?SalesForce在这个口号声中开创了SaaS行业,并成为当今市值460亿美元的SaaS之王.今天谈谈『No ...
- Serverless 架构:用服务代替服务器
Serverless 架构:用服务代替服务器 转载本文需注明出处:EAII企业架构创新研究院(微信号:eaworld),违者必究.如需 加入微信群参与微课堂.架构设计与讨论直播请直接回复此公众号:&q ...
- 腾讯云微计算实践:从Serverless说起,谈谈边缘计算的未来
欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:黄文俊,腾讯云高级产品经理,曾经历过企业级存储.企业级容器平台等产品的架构与开发,对容器.微服务.无服务器.DevOps等都有浓厚兴趣. ...
- 精读《Serverless 给前端带来了什么》
1. 引言 Serverless 是一种 "无服务器架构",让用户无需关心程序运行环境.资源及数量,只要将精力 Focus 到业务逻辑上的技术. 现在公司已经实现 DevOps 化 ...
- 《Serverless架构-无服务单页应用开发》读后感
本书的作者是[美]Ben Rady,译者郑赞美.简传挺,书中作者详细的介绍了如何使用html.js以及amazon提供的诸多云服务(Simple Storage Service(S3).Cognito ...
- 华为云对Kubernetes在Serverless Container产品落地中的实践经验
华为云容器实例服务,它基于 Kubernetes 打造,对最终用户直接提供 K8S 的 API.正如前面所说,它最大的优点是用户可以围绕 K8S 直接定义运行应用. 这里值得一提是,我们采用了全物理机 ...
- InfoQ 趋势报告:架构和设计领域技术演变详解
https://www.infoq.cn/article/R7lWXd0R4VFf3E0bB*38 本文概述了我们对当前“架构和设计”领域的看法,这个领域侧重于基础设施模式.技术框架模式的实现,以及软 ...
- 【译】Serverless架构 - 3
原文: https://martinfowler.com/articles/serverless.html 消息驱动型应用 后台数据处理服务是一个不同的例子. 你要写一个需要快速响应UI请求的以用户为 ...
随机推荐
- 给嵌入式ARM+Linux的初学者
http://blog.csdn.net/lucykingljj/article/details/40619671
- C#获取CPU处理器核心数量的方法_C#教程
https://yq.aliyun.com/ziliao/89096 摘要: 本文讲的是C#获取CPU处理器核心数量的方法_C#教程, 有几条不同的处理器信息,您可以获得有关的信息:物理处理器数量.核 ...
- Spring装配Bean的过程
首先说一个概念:“懒加载” 懒加载:就是我们在spring容器启动的是先不把所有的bean都加载到spring的容器中去,而是在当需要用的时候,才把这个对象实例化到容器中. spring配置文件中be ...
- 解决Bootstrap布局注册表单input标签前增加必填项*提示与input框不在同一行问题
注册表单部分代码如下: <form id="registForm" class="form-horizontal" action="${page ...
- java运行显示“找不到或无法加载主类”的解决办法(linux)
要是配置文件的路径问题.打开终端,输入vi ~/.bashrc添加如下代码即可. # set Java environmentJAVA_HOME=/usr/local/java/jdk1.8.0PAT ...
- UITextView 实现placeholder的方法
本文转载至 http://www.cnblogs.com/easonoutlook/archive/2012/12/28/2837665.html 在UITextField中自带placeholder ...
- 计算从ios照片库中选取的图片文件大小
本文转载至:http://blog.csdn.net/longzs/article/details/8373586 从 iphone 的 照片库中选取的图片,由于 系统不能返回其文件的具体路径,所以这 ...
- LeetCode——Maximum Subarray
Description: Find the contiguous subarray within an array (containing at least one number) which has ...
- Express框架(http服务器 + 路由)
index.js 使用express框架搭建http服务器,和实现路由功能. var express = require('express'); var app = express(); // 主页输 ...
- Android动态添加布局
//1.利用LayoutInflater的inflate动态加载XML mLinearLayout = (LinearLayout)findViewById(R.id.LinearLayout_ID) ...