记录一些云函数的基础知识,混个脸熟
不少同学总是问关于云函数的问题,所以这里发个扫盲的文章吧。
# 云函数是啥?
云函数作为无服务模式的一种实现(FaaS)已经有很多公司在提供了,亚马逊AWS、微软Azure、Google Cloud、IBM Cloud、阿里云、腾讯云、华为云、LeanCloud......
小程序云函数在微信官方文档中的定义摘录:
云函数即在云端(服务器端)运行的函数。在物理设计上,一个云函数可由多个文件组成,占用一定量的 CPU 内存等计算资源;各云函数完全独立;可分别部署在不同的地区。开发者无需购买、搭建服务器,只需编写函数代码并部署到云端即可在小程序端调用,同时云函数之间也可互相调用。
文档地址:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/guide/functions.html
云函数的本质是一个后端服务,不过把服务的粒度拆成了函数级别,代码是单独部署在提供服务的厂商的机器上的,但是它有别于云存储及云数据库等BaaS,是函数即服务(Function as a Service)的实现。
# 腾讯云云函数与小程序云函数的区别
别看都是云函数,二者还是有些区别的,腾讯云云函数(Serverless Cloud Function)是腾讯云为企业和开发者们提供的无服务器执行环境,帮助您在无需购买和管理服务器的情况下运行代码, 是实时文件处理和数据处理等场景下理想的计算平台。小程序云函数当然是为了小程序这个应用场景深度定制的了。
之前曾经发过的一篇文章浅谈腾讯云·云开发与小程序·云开发的区别 ,也有略微提及。
# 1. 支持的语言环境
- SCF:Python、Node.js、Golang、PHP、Java
- 小程序云函数:Node.js8.9
除此之外,环境中内置的依赖也是有差别的,比如腾讯云云函数是内置puppeteer而小程序的云函数则是没有的。
SCF 在已支持的开发语言及版本的标准运行环境外还提供了 Custom Runtime 服务,即可定制化运行环境。通过开放实现自定义函数运行时,支持根据需求使用任意开发语言的任意版本来编写函数,并实现函数调用中的全局操作,如扩展程序的加载,安全插件,监控 agent 等。
# 2. 免费额度
SCF:
计费项 | 每月免费额度 |
资源使用量 | 40万GBs |
调用次数 | 100万次 |
小程序云函数:
资源使用量:4万GBS/月
调用次数:不限
# 3. 其它限制
SCF可以调整运行内存,支持绑定自定义域名,灵活性较高。
小程序云函数存在如下系统限制:
- 云函数(单次运行)运行内存:256Mnote
- 云函数并发数:1000note
- 数据库流量:单次出包大小为16M
- 数据库单集合索引限制:20个
- 单个小程序的小程序端请求频率限制:100 万次/分钟
# 云函数适用场景
- 事件驱动&响应式
- 存在流量突发的情况
- 请求延时要求不高
- 低频请求
- 资源要求低
# 优缺点
# 优势:
- 云端运行:无需采购、部署、运维传统硬件,节约人力及成本
- 高效开发:每个函数单独运行、部署,上传代码后即可自动部署,提升了独立开发和迭代的速度
- 弹性伸缩:根据请求量实现毫秒级实时弹性伸缩,函数未执行不产生任何费用,不需为空闲资源付费
传统的开发方式,一个企业提供软件产品服务需要提前采购资源,根据自己的需求提前预估使用情况,考虑并发限制、峰值请求等,就要购买多台云主机去满足高可用、高并发,而平时这些计算资源大多是闲置的,造成了资源浪费。而云函数可以做到按需使用,弹性扩缩容,对于中小创业公司来讲是可以节省很多成本的。
如何判断业务是否适合上云函数?
- 异步,并发,易于并行化为独立的工作单元
- 无状态,短暂的,冷启动时间要求不高
- 扩展要求差异性较大,请求量无法预估
- 业务需求变更频繁,灵活性要求高,敏捷开发
# 美中不足:
- 无法应对架构特别复杂的情况,不是所有的业务都适合上云的,业务需要细粒度的拆解来决定哪些服务需要上云,这对软件的架构是个挑战,可能需要一个侵入式的改造。
- 不适合应用长时间运行
- 依赖很多第三方服务