华为云 Serverless 核心技术与最佳实践

电子说

1.3w人已加入

描述

一、Serverless 简介

软件架构的发展从原先的单体架构到近十几年的微服务架构,再到现在新兴的 Serverless 架构。单体架构通常把应用的逻辑和功能耦合在一起,部署在 BMS 裸金属机或 VM 上,耦合模式使得一些通用功能或通用逻辑无法灵活复用,经常出现重复造轮子的现象,架构整体上是相对封闭的。

微服务时代对应用做了拆分,组件服务化,诞生了一系列优秀的设计原则,如接口标准化、CS/CD 自动化,使得应用初步具备了弹性和自动容错的能力。

在 Serverless 的框架下,应用的粒度更细,例如以函数为粒度进行管理和开发迭代,应用通过事件驱动的方式触发运行。

Serverless 可以看作是一种云计算服务模型,它允许开发者在不需要管理服务器的情况下通过事件驱动的方式运行应用代码,主要解决资源托管、调度、运维管理等一系列平台型问题,可以看作是 DevOps 的进一步延伸。

serverless

从传统微服务向 Serverless 演进的过程中,资源管理的边界逐步上移。在微服务时代,虚机/容器时代,开发者发布应用,需要管理虚拟化层或更向上的运行时细节;而从 IaaS 到 Serverless,抽象度越来越高,底层细节的屏蔽度也越来越高,对于开发者而言,云的易用性性也在增强,门槛在降低。

Serverless 将是下一代的云计算范式,得益于它在按因付费、自动弹性、免运维等方面的显著优势。通用全场景的 Serverless 能够帮助企业解决更广泛的计算和运行交付的问题。实际上,Serverless 也在过去几年的发展中,逐步增长成为下一代云上交付、运行与交付标准的框架。

二、华为云 Serverless 核心技术

serverless

Serverless 平台的应用托管流程

Serverless 的特点是按用计费、按需计费,如果终端没有流量,平台会自动回收应用资源,不需要为空闲时间付费,需要再次使用时,通过重新启动的方式再次加载。

冷启动或进一步延伸到高并发下的弹性问题,用户侧应用托管到 Serverless 平台上,如果频繁经历冷启动,应用的 QoS 下降,最直观体现在终端用户页面的 Web 应用响应很慢,有超时的风险,导致用户侧体验下降。对云平台侧,冷启动和弹性关系着资源利用率,例如多租户进行混合部署时,预热效率的提升问题,以及平台多用户多应用流量并发上涨时的弹性问题。因此,冷启动和弹性问题是 Serverless 领域广泛关注的技术重点。

为了解决上述问题,华为云 Serverless 做了一系列的探索。

serverless

链路加速:通过高性能解压缩转换与共享内存加速技术,能够把性能提升 2-11 倍;通过公共依赖包分离、预解压与动态按需 link 技术,加速应用冷启动 5- 10 倍。

池化预热、弹性调度:通过资源池化预热、分层预加载与弹性水位控制,实现毫秒级 (< 10 ms) 弹性。

智能预热:以智能、分层资源预热实现负载感知,自适应池化水位控制;采用负载、资源压力预测框架,实现良好扩展性、数据驱动、以及工程师经验的规则注入。

预留实例智能推荐策略:通过建模的方式推算给定时间段大概需要的实例数量,提供高性能、平衡、低成本三种预留实例配置策略。

三、华为云 Serverless 最佳实践

案例一:Mock 服务接入 Serverless

serverless

客户 Mock 服务可以模拟接口的响应,常用于服务打桩,避免由于依赖服务的不稳定,造成自身开发和测试进度的阻塞。在华为云 Serverless 的帮助下,从手动扩缩容变成毫秒级的自动弹性,提升开发、上线效率 100%,资源成本降低 50%

案例二:视频业务基于函数实现 BFF (Backends For Frontends) 模式

serverless

使用函数 BFF 架构后,华为视频登录速度提升 0.6~1s,相比原有方案快 30%~40%。

案例三:基于 Serverless 构建的视频转码服务

serverless

基于 Serverless 构建的视频转码服务,函数编排的能力,由多个函数协同提供完整的功能,比如一个视频处理业务下,有多个视频处理的算子,能够自动弹性伸缩。完整改造后,整个成本降低了 80%。

四、General-purpose Serverless 展望

serverless

未来,边缘、中间件、托管、大数据将全面 Serverless 化,最底层是 Serverless 的 BaaS 的资源、资源池的自动化管理和快速弹性的能力。在底座之上,是跟业务相关的函数计算、容器和托管,三种共存。Serverless 容器将下沉到 Serverless 底座,只需要对底座资源进行管理。在边缘端,传统的容器或是虚机可能无法支撑,采用 Serverless + WASM 是更可行的方案。

审核编辑 黄宇

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分