【音频】如何保证Serverless业务部署更新的一致性|学习笔记

本文涉及的产品
Serverless 应用引擎 SAE,800核*时 1600GiB*时
函数计算FC,每月15万CU 3个月
简介: 快速学习【音频】如何保证Serverless业务部署更新的一致性。

开发者学堂课程【Serverless 技术进阶:【音频】如何保证Serverless业务部署更新的一致性】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/995/detail/15037


【音频】如何保证Serverless业务部署更新的一致性


内容介绍:

一、让发布更安全的:线上异动感知

二、性能心中有数:一键压测函数计算

三、从工具看函数资源评估

四、Serverless Devs与Funcraft/Fcli的对比


一、让发布更安全的:线上异动感知

所谓一致性是指通过工具在本地进行项目部署,此时再有其他人通过其他途径(例如控制台等),对项目进行更新等操作。那么,此时再在本地进行项目部署,是不是会直接覆盖?

例如,当用户A在本地更新了业务,因为一些特殊情况,导致出现了一个线上异常x,此时用户B重新更新,将这个内容修复了,但是B没有及时同步给A这个事情,A又更新了新的功能,直接覆盖了B的内容,这个时候之前的异常x又出现了,如果此时在A更新的时候,可以感知到线上资源已经变动,那么这种事情就不会再次发生。

目前基于Serverless Devs的阿里云函数计算组件,已经支持了线上“异动”的感知能力。

如何进行部署前的检测:

1.部署前检测

当通过Serverless Devs开发者工具进行项目部署完成,再模拟其他用户在控制台对配置信息进行更新,完成之后,通过plan功能可以进行部署前的资源检测,可以看到,系统已经成功的感知到了变更。

2.部署异动感知

继续上面的例子,如果在部署的时候直接执行s deploy,系统同样会在部署的时候,告知代码内容发生了变化,并且让使用者主动选择use-remote或者use-local,进行继续部署。

3.在自动化流程中的策略

代码在其他场景被更新,需要在当前得到感知,这个事情其实是非常重要的,和代码的安全发布密不可分。而此时,通过Serverless Devs是可以做到的。

如果已经有了一个项目,想集成到cd流程,不想出现交互式操作,应该如何处理?此时提供一个--use-local/--use-remote参数,用来强行指定优先使用的配置,通过这样的指令就可以实现无交互的部署。例如:

优先使用本地配置: s deploy --use-local

优先使用线上配置: s deploy --use-remote


二、性能心中有数:一键压测函数计算

1.实现原理

image.png

stress命令原理是通过创建辅助函数,对目标函数进行压测,架构简图如下:

①stress start指令会根据组件内置配置,创建辅助函数

②辅助函数创建完成后,将会调用目标函数,压测参数放置在调用负载中,辅助函数被调用后就会基于Python Locust对目标函数发起压测试

③发起测试之后,将压测结果返回给本地

④本地收到结果后,会展示结果并生成html报告文件

2.操作案例

有资源描述文件(Yam1)时,可以直接执行s stress start开始目标函数压测;

在没有资源描述Yam1文件时,纯命令行格式,需要指定服务所在地区以及服务名称,函数等,并根据返回信息打开对应的压测报告,这里的操作案例在75-77页有展示(文本4-6页)。


三、从工具看函数资源评估

在Serverless领域内,通常会出现以下两种使用场景:

1.CPU密集型场景

对于CPU密集型场景,例如音视频处理、AI推理或图片处理等,一般会选择使用单实例单并发。由于该类场景的函数内存大小和 CPU能力成正比,因此需要根据函数是成本敏感型还是延迟敏感型选择合适的内存规格。

2.I/0密集型场景

对于I/0密集型场景,一般会选择使用单实例多并发。该类场景下由于函数内存和 CPU能力成正比,建议将函数内存规格设置足够大,但可能会出现浪费资源的现象,很难选择合适的单实例并发值。

针对在以上两种使用场景无法设置合适的参数规格的情况,ServerlessDevs为您提供了探测功能,可以实现内存探测和并发度探测,获取满足您需求的参数配置信息。eval命令是对函数进行探测的命令;通过eval指令,可以对函数探测内存(单实例单并发)或者探测并发度(单实例多并发)。例如给CPU 密集型场景的函数设置合适的内存,给I/0密集型场景的函数设置合适的并发值,根据探测结果,获取满足需求的最佳内存大小或最佳并发度值。

注意:这个命令只是针对开发上线前阶段的函数,不要对生产函数执行探测操作

在78-81页(文本7-9页)分别以探测CPU密集型场景事件函数为例,介绍如何实现内存模式探测,以I/O密集型场景的HTTP函数为例,介绍入河对函数实现并发度的探测。


四、Serverless Devs与Funcraft/Fcli的对比

Serverless Devs与Funcraft/Fcli等工具无论是在使用形式上还是在功能对比上,以及应用场景上都有有比较明显的区别。

1.形式对比

fc组件支持资源描述文件和纯命令行模式,而funcraft只依赖资源描述文件,fcli只支持纯命令行模式

2.功能对比

fc组件支持应用部署、应用移除、构建、远程调用、本地调用、查看日志、查看指标、NAS操作、同步操作、版本、别名、预留、按量资源、层、端云联调、一键压测、内存和并发度探测、远程调试、函数异动感知、端到端部署、多账号管理和API操作

funcraft只支持应用部署、构建、远程调用、本地调用、NAS操作

fcli支持应用部署、应用移除、API操作

3.场景对比

fc组件支持六个场景:

①用户可能同时有测试账号和线上账号,或者个人账号和公司账号,需要进行进行不同账号的切换。

②用户需要在一个项目的执行前后,进行其他相关的行为定义,例如部署前需要进行 build,部署后需要进行版本的发布,相关文件的上传,灰度的设置等。

③用户需要一键部署端到端的项目,例如将前端代码上传到对象存储,后端代码上传到函数计算,同时部署 API网关、CDN等相关业务。

④用户需要在本地进行调试,但是有一些网络环境时线上的VPC,此时需要在本地连接到线上的VPC环境,进行代码的调试等。

⑤在进行项目部署时,Yaml需要从环境变量获取一些敏感信息,或者从其他的文件获取信息,也或者从已经部署完成的项目获得返回值作为入参,进行项目的部署。

⑥不依赖 Yaml进行相关的原则性的操作,例如查看函数列表,服务列表,删除某个函数、服务,查看版本列表等。

fcli只支持一个场景

4.迁移案例

(1)从Funcraft迁移到Serverless Devs的方法

【推荐】Yaml格式切换:这种方法是将Funcarft规范的资源描述文档(例如template.yaml 文件),转换成符合Serverless Devs规范且使用FC组件的资源描述文档(例如 s.yaml 文件)。可以在 Funcraft项目目录下,通过fun2s命令,实现 Yaml规范转换,可以将原有的 Funcraft规范的template.yaml转换成支持 Serverless Devs规范的s.yaml。这里可以看一下转换前,转换后的对比。

资源信息重新同步:这种方法是将线上的函数资源,直接同步到本地,包括线上函数的代码和相关的配置(此时的配置是符合Serverless Devs规范且使用FC组件的资源描述文档)。指定好对应的服务名、函数名等。

(2)从Fcli迁移到Serverless Devs的方法

从Fcli迁移到Serverless Devs的项目,通常是进行函数管理或者是与自动化脚本集成的需求,此时可以考虑使用API直接进行迁移,FC组件的API能力是直接操作函数计算API的功能。

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
5天前
|
存储 人工智能 弹性计算
函数计算部署 AI 大模型解决方案测评
函数计算部署 AI 大模型解决方案测评
|
2月前
|
消息中间件 JavaScript 中间件
函数计算产品使用问题否会自动进行打包部署
本文解答了五个关于阿里云函数计算的常见问题。包括:WebIDE编写的Node.js代码如何自动打包部署;如何为fc-stable-diffusion-plus开启API功能;如何在代码中主动结束实例并重启新实例处理触发器;如何在Koa中读取invoke事件消息;以及解决异步事件未触发的问题。提供了详细的解决方案和注意事项,帮助用户更好地理解和使用函数计算服务。[查看详情](https://developer.aliyun.com/ask/649609)
24 1
|
1月前
|
JSON Serverless 数据格式
体验函数计算一键部署 Flux 超写实文生图模型部署
体验函数计算一键部署 Flux 超写实文生图模型部署
|
1月前
|
JSON 物联网 Serverless
|
2月前
|
运维 Serverless PyTorch
函数计算产品使用问题之ComfyUI除了通过WebUI页面进行,还有什么其他方法部署
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
19天前
|
人工智能 自然语言处理 Serverless
阿里云函数计算 x NVIDIA 加速企业 AI 应用落地
阿里云函数计算与 NVIDIA TensorRT/TensorRT-LLM 展开合作,通过结合阿里云的无缝计算体验和 NVIDIA 的高性能推理库,开发者能够以更低的成本、更高的效率完成复杂的 AI 任务,加速技术落地和应用创新。
|
2月前
|
机器学习/深度学习 机器人 Serverless
FaaS 的应用场景
FaaS 的应用场景
|
2月前
|
Serverless API 异构计算
函数计算产品使用问题之修改SD模版应用的运行环境
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
2月前
|
运维 Serverless 网络安全
函数计算产品使用问题之通过仓库导入应用时无法配置域名外网访问,该如何排查
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
14天前
|
Kubernetes Java Maven
揭秘无服务器革命:Quarkus如何让Java应用在云端“零”负担起飞?
本文介绍如何使用Quarkus从零开始开发无服务器应用,通过示例代码和详细步骤引导读者掌握这一技术。无服务器架构让开发者无需管理服务器,具有自动扩展和成本效益等优势。Quarkus作为Kubernetes Native Java框架,优化了Java应用的启动速度和内存使用,适合无服务器环境。文章涵盖环境搭建、项目创建及部署全流程,并介绍了Quarkus的扩展性和监控工具,助力高效开发与应用性能提升。
24 9

相关产品

  • 函数计算
  • 下一篇
    无影云桌面