总结
我在成长过程中也是一路摸爬滚打,没有任何人的指点,所以走的很艰难。例如在大三的时候,如果有个学长可以阶段性的指点一二,如果有已经工作的师兄可以告诉我工作上需要什么,我应该前面的三年可以缩短一半;后来去面试bat,失败了有5、6次,每次也不知道具体是什么原因,都是靠面试回忆去猜测可能是哪方面的问题,回来学习和完善,当你真正去招人的时候,你就会知道面试记录是多么重要,面试官可以从面试记录里看到你的成长,总是去面试,总是没有成长,就会被定义为缺乏潜力。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
1.2.1Serverless函数计算适用场景
Serverless函数计算适用场景主要有以下三类,Web类应用IoT,媒体处理类应用,AI处理应用
Web类应用
解放端侧开发,让端开发者更快、更灵活开发各种应用,无需关注后端服务
-
小程序后端
-
Web后端
-
问答机器人
-
前端BFF
IoT,媒体处理类应用
以事件驱动的方式执行服务,按需供给,开发者无需关注业务波峰波谷,节省闲时成本,最终降低运维的成本
-
实时图片处理
-
实时数据流处理
-
loT事件处理
-
运维告警处理
AI处理应用
各行各业智能化深入带来更多的应用开发场景,通常需要集成各类服务快速上线
-
视频直播
-
Al推理
-
人脸识别
-
车牌识别
1.2.2六个典型的应用场景
典型场景一: Web/App/小程序后端
场景需求特点:
-
业务变化快,
-
上线周期短
函数计算优势:
-
无需管理服务器,
-
开发上线快
典型场景二:BFF/SSR
场景需求特点:
BFF/SSR和业务强相关,通常由前端开发,但前端并不擅长服务器的部署、运维
函数计算优势:
-
无需管理服务器
-
前端可使用熟悉的技术栈开发
典型场景三:事件触发
场景需求特点:
1、业务事件频次不高或波峰波谷明显
函数计算优势:
-
按需付费
-
毫秒级自动弹性
典型场景四:服务间快速集成
场景需求特点:
-
1、业务需要串联多个服务,被集成服务提供了API或SDK
-
2、业务创新需要方案能快速打通试错,并具有一定的扩展性
函数计算优势:
-
多语言开发,事件驱动特性方便对接各类服务
-
按需自动弹性即保证了扩展性又兼顾了成本
典型场景五:视频转码函数工作流
场景需求特点:
-
多步骤弹性并发处理,步骤耗时长
-
需要容错
函数工作流优势:
-
自动弹性满足大并发
-
状态维护,失败重试保证可靠
典型场景六: 安全运维函数工作流
场景需求特点:
-
灵活编排
-
自动化和人工处理相结合
函数工作流优势:
-
编排更灵活,支持深度自定义逻辑
-
通知+回调的方式支持人工介入流程
2.1Serverless趋势及服务全景
2.1.1Serverless趋势及华为云Serverless服务
Serverless是下一-代默认的计算范式,将在未来5- 10年内成为云的首要交付模式
Serverless的价值:能够为应用屏蔽基础设施,提供自动化运行环境、随时按实际用量计费、免运维的能力
2.1.2FunctionGraph2.0使用场景与客户选择
2.2典型客户场景
2.2.1华为视频:前端基于函数开发中间层,实现前后端解耦,开发上线效率提升1 00%+
1.场景&问题
场景:视频App前端展示的内容随业务需要经常变化,包括排版更新,新功能上线
问题:前端变化的内容往往只涉及后端数据的重新组合或者格式转换,但却需要前后端一起配合修改,沟通成本高,版本上线慢
2.解决方案
前端使用自己熟悉的Node.js语言开发函数,作为中间层调用后端微服务,对数据裁剪、聚合以适配前端业务需要。
3.价值&收益
前后端彻底解耦,前端聚焦业务,后端仅需提供通用接口,不再关心数据如何展示,减少了
沟通成本
前端只需开发中间层业务函数,业务服务器的部署、运维和扩容,都由函数计算平台托管,开发上线效率提升100%以上
2.2.2阿联酋xx: Serverless化构建 车队管理系统,上线周期缩短一 半,总成本降低30%
2.2.3XX车企:函数结合AI等服务,毫秒级弹性伸缩和NoOps支持实时小碰撞检测
2.3FunctionGraph主要能力
2.3.1FunctionGraph 2.0:基于华为元戎的新一代函数计算与编排服务,8大特性发布
2.3.2特性1:丰富的函数开发语言及触发方式让设计更灵活
2.3.3特性2:可视化拖拽式函数流支持编排复杂业务场景
2.3.4特性3:统一-插件支持云上和云下的开发与调试
2.3.5特性4: Http函数让WEB服务近乎0成本改造,享受Serverless优势能力
2.3.6特性5:函数支持容器镜像,简化应用Serverless化
2.3.7特性6:函数支持在运行时动态指定资源,灵活调度节省成本
2.3.8特性7:百毫秒冷启动时延,单实例多并发,毫秒级弹性
2.3.9特性8: 1ms粒度按量计费,节省开支
3.1.函数计算关键技术原理
3.1.1Serverless架构优势
3.1.2Serverless函数带来的挑战:冷启动
-
函数被伯克利称为“异步调用的微服务”;
-
从Long Running变为Event Driven,函数的启动时延成为关键指标,直接影响哪些应用能够函数化;
3.1.3冷启动时延优化
平台侧优化
1.池化
大小自适应的空实例池,按当前池消耗速率和容器产生速度动态调整容器池大小,优化启动速度同时降低增加空函数实例的成本
2.网络优化
简化网络配置,提升启动速度
3.函数代码预加载
基于LRU ( Least Recently Used )的多级代码包缓存,预创建不含代码包的空实例,优化容器首次启动与调度时延
4.解压缩优化
高性能的压缩算法提升解压速度和压缩比
用户侧优化
预留实例:
预留实例是将函数实例的创建和释放交由用户管理,当您为某一函数创建了预留实例,函数_ I作流收到此函数的调用请求时,会
优先将请求转发给您的预留实例,当请求的峰值超过预留实例处理能力时,剩余部分的请求将会转发给按量实例,由函数工作流自动为您
分配执行环境。预留实例在创建完成后,会自动加载该函数的代码、依赖包以及执行初始化入口函数,且预留实例会常驻环境,消除冷启
动对业务的影响。
1.减少代码包大小
代码包过大会增加传输、解压、加载时间,通过去冗余文件等减少代码包大小对冷启动时延优化效果较明显
2.选择合适语言
nodjs、python、 golang- -般优于java, 针对java也可以尝试编译成本地代码方式
3.降低代码初始化时间
升级依赖包,合并依赖文件等
4.选择合适的内存
函数内存越大,计算能力越强,冷启动表现越优
5.预留实例
1.根据业务 波峰波谷配置固定预留实例,超出部分通过弹性实例解决
2.定制自己业务 需要的预留实例策略
3.1.4Serverless运行模型带来的注意事项
总结
我在成长过程中也是一路摸爬滚打,没有任何人的指点,所以走的很艰难。例如在大三的时候,如果有个学长可以阶段性的指点一二,如果有已经工作的师兄可以告诉我工作上需要什么,我应该前面的三年可以缩短一半;后来去面试bat,失败了有5、6次,每次也不知道具体是什么原因,都是靠面试回忆去猜测可能是哪方面的问题,回来学习和完善,当你真正去招人的时候,你就会知道面试记录是多么重要,面试官可以从面试记录里看到你的成长,总是去面试,总是没有成长,就会被定义为缺乏潜力。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
3.1.4Serverless运行模型带来的注意事项
总结
我在成长过程中也是一路摸爬滚打,没有任何人的指点,所以走的很艰难。例如在大三的时候,如果有个学长可以阶段性的指点一二,如果有已经工作的师兄可以告诉我工作上需要什么,我应该前面的三年可以缩短一半;后来去面试bat,失败了有5、6次,每次也不知道具体是什么原因,都是靠面试回忆去猜测可能是哪方面的问题,回来学习和完善,当你真正去招人的时候,你就会知道面试记录是多么重要,面试官可以从面试记录里看到你的成长,总是去面试,总是没有成长,就会被定义为缺乏潜力。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
[外链图片转存中…(img-rUpUGeyK-1715741238346)]
[外链图片转存中…(img-SICTngEf-1715741238347)]