从“预见”到“遇见” — SAE引领应用步入Serverless全托管新时代

简介: 随着云原生时代的到来,企业应用也开始面向云进行容器化、微服务化的构建。过程中产生了进阶式的变化,主要是应用的开发设计、应用的交付以及线上运维的变化。

从“预见”到“遇见”

SAE引领应用步入Serverless全托管新时代

——黛忻

阿里云SAE产品经理

image.png

近年来,随着互联网的普及,企业数字化发展越来越快,技术架构也经历了几度更迭。尤其是在线业务部分,企业最初的需求是将业务尽可能在线化,于是产生了早期的单体应用。即便今天,如果有想法要快速落地、试错,单体应用依然是最为推荐的方式。


随着在线业务复杂性的增加和访问的增长,逐渐演进到分布式应用,前端加上负载均衡,后端引入消息缓存等中间件,数据库开始分库分表,才最终得以应对流量的增加。


随着云原生时代的到来,企业应用也开始面向云进行容器化、微服务化的构建。过程中产生了进阶式的变化,主要是应用的开发设计、应用的交付以及线上运维的变化。


服务架构的演进为开发者带来了便利,同时也带来了一定的复杂度。新技术上手门槛较高,容器和微服务是两个典型的拦路虎。在框架选型、服务治理 k8s 运维方面缺少经验,短时内也无法储备专业人员。此外,即便微服务化和容器化之后,企业依然需要关注服务器的配置,人工评估容量和服务器的运维工作,同时还会面临高性能和稳定性的挑战,因此无法享受云带来的最大便利。

image.png

Serverless 的出现带来了跨越式的变革,为企业数字化转型带来了更多机遇。在此模式下,服务器和操作系统的管理部署、运维、资源分配和缩容能力等全部由云计算厂商提供,计算能力真正像水电煤一样被便捷地提供。它能够将原先在传统应用环境中的通用能力转化成云服务,客户可以低成本、高效力地触达。


Serverless最重要的价值可以归纳为三点:


通过基础设施解耦、极致的弹性和故障自动处理等提供永远在线的服务,无须担心宕机。


②  通过高效的研发框架以及DevOps 新形态,做到秒级市场响应。


③  抹平了头部互联网公司与传统企业之间技术竞争力的代差,让传统企业面临大量技术升级和重构时,能够从容不迫,不会出现人才缺口,甚至能够弯道超车。


   企业在上云过程中,如何接入 Serverless


   阿里云提供了一款继 FaaS 形态之外的面向应用的 Serverless 产品——Serverless 应用引擎,简称SAE作为业界首款面向应用的Serverless产品,它提供了全托管、免运维、高弹性的使用体验,能够让应用上云更加开箱即用,支持开源的微服务、定时框架以及 web 应用全托管,并提供了开源侧的增强和企业级的特性。

 image.png

上图为产品的功能架构。


SAE 的底座是基于阿里云的沙箱容器 2.0 IaaS 的基础资源层,提供了平台托管的开发集群,帮助用户屏蔽了IaaS 和复杂的 k8s 运维。


在此之上,SAE 提供了三大核心模块:


应用管理提供了整个应用生命周期的管理和多种发布策略,还具备冷启动加速等先进的技术竞争力。


②  在开源Spring CloudDubbo 基础之上,提供了阿里巴巴近十年来的微服务最佳实践。在开源基础上,额外提供了微服务的无损上下线、限流降级、全链路灰度、服务鉴权等高级特性。


③  提供了运维配套和企业级增强等能力,比如自动弹性、权限隔离等。


基于以上核心能力,无论是Spring Cloud 应用,还是批处理类型的应用,或是 PHP 等多语言的应用,都可以直接通过 war包、jar包、php zip包或 Docker 镜像等方式直接部署到 SAE 上,且能够享受 SaaS 类服务集成的体验。


此外,在开发者工具方面也做了良好的集成,比如能够无缝对接JenkinsTerraformServerless Devs 等开发者工具,为开发者提供非常好的体验。


SAE 的核心竞争力主要包括四大部分:


①   零代码改造。无论是微服务应用还是单体应用,或是开源的定时任务框架,都可以无缝迁移到 SAE同时降低了用户使用 k8s 的门槛,支持代码包部署。


②    弹性效率。能够提供 15 秒的极致弹性效率,让应用端到端地快速扩容,应对突发流量。


③    降本提效。基于 SAE 一键启停的能力,能够实现多套环境按需启停,降本且提效。


④    启动效率。 SAE 联合 Dragonwell突破了 Java 冷启动瓶颈,使得 Java 冷启动的效率提升了40%


因此,可以说SAE 覆盖了应用上云的完整场景,让企业上云更加开箱即用。

image.png

Serverless 微服务作为当今业界非常火热的名词,较为广泛的定义为:CI/CD 流水线,加上内置的高效能研发框架,再加上屏蔽基础 IaaS 层或 k8s 底座,并且提供了端到端的可观测能力,以及一些自动弹性和流量治理服务。


而阿里云的 SAE+MSE 可以称作 Serverless 服务的最佳实践。基于SAE ,以应用为中心,在 SAE 的应用启动过程中内置 MSEagent ,即提供了一整套微服务的能力。加之其底层天然屏蔽了 k8s 底座,提供了一套无服务器的架构,因此可以将 SAE+MSE看作 Serverless 的最佳实践。同时能够做到 100% 拥抱开源并回馈开源,因为 MSE 团队做了大量开源步道以及在开源基础上做了非常多增强。


基于这套 Serverless 微服务的最佳实践,能够使开发效率提升70%,成本降低60%

image.png

SAE 的弹性能力不同于 ECS k8s 的弹性,它的弹性指标更丰富,弹性策略更灵活,主要提供了三种弹性策略。


基于基础监控指标和业务监控指标出发的水平伸缩:比如在开源的开发基础之上额外增加了面向业务层的弹性能力,比如QPSRTTCP的连接数等,基于这些业务指标来精准地实现弹性,整体弹性容量的预估会更加精确。一般适用于有突发流量或点击脉冲的场景。


②  基于定时时间段触发的水平伸缩:可以设置何时开始扩/缩容,扩/缩容到多少实例。同时,SAE 提供了白屏化的操作,相比于自己使用开源的 K8S 装一个 HPA Controller 更简单。


③  基于定时弹性和指标弹性混用的弹性策略(业界首款):很多客户的业务都有潮汐特性,且会伴随流量突发,比如视频直播等场景。因此,我们提供个 了基于指标弹性做兜底,再针对固定时间段的流量峰值叠加定时弹性作为增强的方案,既保证整个弹性的灵活度,又极大满足了用户使用体验,只需要配置一次规则即可满足所有需求。

image.png

电商类、新零售、互娱行业等往往会出现一些不可预期的突发流量。以往一般通过提前预估峰值,按照峰值保留 ECS 资源来应对,但时常会出现容量预估不准,导致资源浪费或不足的情况,更重要的是会影响系统的SLA


采用压测工具加SAE 的方案之后,可以根据压测结果精准地设置弹性阈值,与ARMS 的实时监控指标做对比,系统会自动进行扩缩容操作,无须再做容量的规划,极大节省了硬件成本,实现了秒级的弹性效率,得以轻松应对峰值大考。在紧急情况下,还能够通过限流降级的杀手锏来避免应用雪崩。

image.png

SAE 提供了高效闭环的 DevOps 体系,它完整地覆盖了从开发态到部署态到运维态整个闭环过程。它提供了三种企业级 CI/CD 持续集成解决方案:


无缝对接开源 CI/CD 工具 Jenkins:通过内置的 Maven 插件,可以完成从source code 到构建到整个部署的完整过程。它能够支持war包、jar包和镜像部署等几种模式。


②  云上功能最全的 CI/CD 方案:它与 Jenkins 的区别在于,可以将代码直接托管到云上,由云效来完成代码托管。还能够做到代码侧的安全管理,可以定制流水线,提供完整一致的构建运行的环境。它的功能比较齐全,一般适用于中型规模的企业。


③  最轻量、最易用的 CI/CD 方案:通过镜像仓库和阿里云的容器镜像服务来完成SAE 的部署。它的轻量在于通过 webhook 将代码仓库打通,在容器镜像服务上定制一些构建镜像的规则和触发器的规则,即可完成在代码提交时自动构建和部署的过程。如果使用企业级的容器镜像服务,它还能实现镜像的安全扫描、防漏洞、全球多域分发等能力。

image.png

此外,还可以将SAE ECS 混部,将 ECS 作为常态保有的部分,SAE 作为弹性资源池,混部方案主要适用于两种场景:


场景一:从 ECS 陆续迁移到 SAE 的中间过渡方案,能够提升迁移过程的稳定性。


场景二:将SAE 完全作为弹性资源池作备用。此方案需要保证同个应用的 ECS 实例和SAE 实例都能挂载到同一 sob 后端,并设置好权重比例。如果是微服务应用,还需注册到同一个注册中心。此外,客户也需要做一些适配。


若要复用客户自建的发布系统,需要保证每次发版时 SAE 的实例和 ECS 的实例版本一致;若复用客户自建的监控系统,需要将 SAE 的监控数据和 ECS 的监控数据整合在一起。流量高峰到达时,弹性模块会将弹性实例弹到 SAE 上,极大提升了弹性扩容效率,也降低了成本。


SAE 拥有三个重磅新特性:

1.  支持 Terraform

image.png

作为国内外大客户首选的云上工具,Terraform 的价值在于基础设施及代码,它能够自动配置基础设施,帮助企业以更高速度、更低风险、更低成本实现云应用程序的开发、部署和扩展,极大提高了自动化运维的效率。


这一点在 SAE 落地过程中也得到了非常好的体现。在没有接入Terraform 之前,开发人员需要通过控制台或者云上来部署 SAE不仅需要理解每个 Open API 的定义,还需要清晰地知道多个SAE Open API 之间是否存在互斥关系,是否有串行调用的行为,极易出现线上风险。


而接入Terraform 之后,开发人员无须理解 API 代码的形式,只需将所要管理的资源定义在模板之中即可,操作 SAE 的资源更加安全,对接 CI/CD 以及接到 GitOps 也会更加简单。更重要的是,它还提供了资源编排能力,能够一键式部署 SAE 以及依赖的其他资源,从 0 1 来完成建站,效率大幅提升。


因此,SAE 拥抱了 Terraform 生态,无疑为开发者带来极大的便利。


2.  提供了 PHP 的一站式应用托管。

image.png

PHP 作为最流行的服务器编程语言,牢牢占据榜首位置近十年,全球 82.8% 的网站都是基于 PHP 来开发。


大多数开发者通过市面上常见服务器的运维面板来图形化地运维管控应用。但这些面板存在不少痛点:


第一,只能支持单机的运维,缺少集群的管理,需要逐台操作运维;第二,缺少应用侧的监控能力,应用上云需要自研 APM ;第三,流量突增时,弹性效率无法保证;第四,某些 web 应用的静态文件比较大且更新频繁,如果通过ECS 全量部署,需要耗费1-2分钟,前端体验非常差。


针对以上痛点,SAE 提供了免运维、高弹性、无缝集成 APM 监控的 PHP 全托管服务。在框架方面, SAE 支持了 LaravelThinkPHPWsoole 等流行的框架;在运行环境方面,支持在线应用架构的LNMP 架构,默认提供了PHP+FPM+Ngins 的配置。此外,虽然 SAE 的底座是 K8s 但在产品侧支持 Docker 镜像和 PHP zip包的部署,大大降低了用户的使用门槛。


SAE PHP 应用托管功能矩阵也颇为丰富,比如开发调试类的上传/下载、内置 Xdebug 等,运营时的弹性伸缩、APM 等能力,还能够通过NAS/OSS独立管理静态文件和目录。有了上述能力,可以非常好地支撑 PHP 的几个典型场景,比如静态站点的部署、远程调试、多站点部署,比如存量的ECS 或者宝塔面板的应用往SAE 迁移。


3.  SAE Job正式邀测。


SAE Job功能主要针对以下几个方面的痛点:


异步任务和在线业务通常采用混部的方式,资源共用,稳定性差,SLA 得不到保证。


②  成本偏高,资源利用率低,任务结束无法立即释放资源。


③  任务失败后需要人工重启,运维效率低,且企业需要为此付出非常多人力资源。


④  缺少可观测性和报警,对于任务的失败与成功缺少可视化的明细,失败后无法及时予以报警通知。


基于以上痛点,SAE 提供了全托管、免运维的任务处理平台,能够使开源的 XXL job 等任务框架0改造迁移,且深度地融合了微服务的生态,兼容开源的k8s

image.png

上图为 SAE Job 的功能架构图,底座依然是基于平台提供的全托版k8s,帮助用户屏蔽IaaS k8s 的运维。在此之上提供了任务管理界面,其中包含大量功能矩阵,提供了任务模板的能力以及任务启停的能力,能够详细记录每个任务执行的状态,且在开源 XXL job 的基础之上提供了一些高级特性,比如分片、监控报警、支持单机广播并行计算,能够支持任务幂等以及失败重试等。


上述丰富的任务管理界面,可以通过 war 包、jar 包或 Docker 镜像将任务部署到 SAE 上。能够支持几种调用方式,比如通过 Open API SDK的方式,或在Event Bridge 侧编辑触发器来直接部署到SAE


SAE Job 适用于以下几类场景:基于时间驱动的定时任务,比如整点发优惠券、更新收益;批量数据处理、按月统计报表等实时性要求不高的场景;异步任务解耦场景,比如更新一些活动的状态,异步实现离线查询,与当前的业务逻辑做解耦。


SAE Job 与开源 XXL job 相比,较大的优势在于能够深度融合微服务生态。有些任务在启动过程中需要依赖一些微服务,比如查询产品中心,更新产品的变化,再投递到第三方,过程中与微服务有比较多交互,而 SAE 提供了统一的入口和统一的界面,使得客户微服务与 job 调用的诉求得到了非常好的满足。


综上,SAE job 对于客户的价值能够归结于以下4 点:


高可用:任务运行失败后能够自动重试,得到自愈。


②  免运维:基于 Serverless 架构,提供了免运维和高弹性的特性。


③  节省成本。


④  开源增强特性:比如与微服务生态的集成、任务分片等。


SAE 作为面向应用的Serverless产品,体现了云原生先进技术的完美融合,将容器化微服务和Serverless 最佳实践完美融合在一起,提供了开源微服务、开源的任务框架和单体应用的Serverless 全托管,能够实现“来了就用,功能齐全,用完即走”的效果。

 

相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
4月前
|
人工智能 运维 Serverless
函数计算 × MSE Nacos : 轻松托管你的 MCP Server
本文将通过一个具体案例,演示如何基于 MCP Python SDK 开发一个标准的 MCP Server,并将其部署至函数计算。在不修改任何业务代码的前提下,通过控制台简单配置,即可实现该服务自动注册至 MSE Nacos 企业版,并支持后续的动态更新与统一管理。
719 57
|
4月前
|
人工智能 运维 Kubernetes
Serverless 应用引擎 SAE:为传统应用托底,为 AI 创新加速
在容器技术持续演进与 AI 全面爆发的当下,企业既要稳健托管传统业务,又要高效落地 AI 创新,如何在复杂的基础设施与频繁的版本变化中保持敏捷、稳定与低成本,成了所有技术团队的共同挑战。阿里云 Serverless 应用引擎(SAE)正是为应对这一时代挑战而生的破局者,SAE 以“免运维、强稳定、极致降本”为核心,通过一站式的应用级托管能力,同时支撑传统应用与 AI 应用,让企业把更多精力投入到业务创新。
581 30
|
5月前
|
存储 人工智能 Serverless
函数计算进化之路:AI 应用运行时的状态剖析
AI应用正从“请求-响应”迈向“对话式智能体”,推动Serverless架构向“会话原生”演进。阿里云函数计算引领云上 AI 应用 Serverless 运行时技术创新,实现性能、隔离与成本平衡,开启Serverless AI新范式。
576 12
|
10月前
|
SQL 分布式计算 Serverless
鹰角网络:EMR Serverless Spark 在《明日方舟》游戏业务的应用
鹰角网络为应对游戏业务高频活动带来的数据潮汐、资源弹性及稳定性需求,采用阿里云 EMR Serverless Spark 替代原有架构。迁移后实现研发效率提升,支持业务快速发展、计算效率提升,增强SLA保障,稳定性提升,降低运维成本,并支撑全球化数据架构部署。
1083 56
鹰角网络:EMR Serverless Spark 在《明日方舟》游戏业务的应用
|
10月前
|
人工智能 开发框架 安全
Serverless MCP 运行时业界首发,函数计算让 AI 应用最后一公里提速
作为云上托管 MCP 服务的最佳运行时,函数计算 FC 为阿里云百炼 MCP 提供弹性调用能力,用户只需提交 npx 命令即可“零改造”将开源 MCP Server 部署到云上,函数计算 FC 会准备好计算资源,并以弹性、可靠的方式运行 MCP 服务,按实际调用时长和次数计费,欢迎你在阿里云百炼和函数计算 FC 上体验 MCP 服务。
818 30
|
8月前
|
存储 编解码 Serverless
Serverless架构下的OSS应用:函数计算FC自动处理图片/视频转码(演示水印添加+缩略图生成流水线)
本文介绍基于阿里云函数计算(FC)和对象存储(OSS)构建Serverless媒体处理流水线,解决传统方案资源利用率低、运维复杂、成本高等问题。通过事件驱动机制实现图片水印添加、多规格缩略图生成及视频转码优化,支持毫秒级弹性伸缩与精确计费,提升处理效率并降低成本,适用于高并发媒体处理场景。
437 0
|
5月前
|
人工智能 运维 安全
聚焦 AI 应用基础设施,云栖大会 Serverless AI 全回顾
2025 年 9 月 26 日,为期三天的云栖大会在杭州云栖小镇圆满闭幕。随着大模型技术的飞速发展,我们正从云原生时代迈向一个全新的 AI 原生应用时代。为了解决企业在 AI 应用落地中面临的高成本、高复杂度和高风险等核心挑战,阿里云基于函数计算 FC 发布一系列重磅服务。本文将对云栖大会期间 Serverless+AI 基础设施相关内容进行全面总结。
|
5月前
|
运维 Kubernetes 测试技术
应用多、交付快,研发运维怎么管?看云效+SAE 如何一站式破局
通过在云效中创建 SAE 服务连接并关联集群,团队可将应用环境直接部署到 SAE,实现从代码提交、镜像构建到 SAE 部署的自动化流水线。该集成打通了研发与运维的壁垒,特别适用于应用数量多、团队规模大、交付节奏快的组织,助力企业实现敏捷、可靠的持续交付。
|
5月前
|
人工智能 Kubernetes 安全
重塑云上 AI 应用“运行时”,函数计算进化之路
回顾历史,电网的修建,深刻地改变了世界的经济地理和创新格局。今天,一个 AI 原生的云端运行时的进化,其意义也远不止于技术本身。这是一次设计哲学的升华:从“让应用适应平台”到“让平台主动理解和适应智能应用”的转变。当一个强大、易用、经济且安全的 AI 运行时成为像水电一样的基础设施时,它将极大地降低创新的门槛。一个独立的开发者、一个小型创业团队,将有能力去创造和部署世界级的 AI 应用。这才是技术平权的真谛,是激发全社会创新潜能的关键。
|
10月前
|
Kubernetes 数据可视化 Java
SAE 实现应用发布全过程可观测
本文聚焦阿里云Serverless应用引擎(SAE)用户在发布过程中的痛点,如“发布效率低、实例启动过程不透明”等问题。通过分步骤可视化解决方案,帮助用户明确问题、理解原因并最终解决,提升SAE平台使用体验。文章详细剖析了发布过程慢、信息透出不足及实例启动黑盒等痛点,并提出通过可观测、可解释和可优化的策略解决问题,同时展示了具体实现效果与后续优化规划。
593 68

热门文章

最新文章

相关产品

  • 函数计算
  • Serverless 应用引擎