伊对App视频直播场景的Serverless技术实战

本文涉及的产品
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
函数计算FC,每月15万CU 3个月
简介: 阿里云自研的Serverless产品函数计算FC是事件驱动的全托管计算服务,完美契合了伊对App在直播截帧场景中的需求和痛点。

北京米连科技有限公司成立于2015年,是国家高新技术企业,旗下品牌伊对App上线于2018年,专注于移动端交友和相亲,将视频、直播和线上红娘创造性地融合在一起,开辟了视频恋爱社区的独立赛道,为单身人群提供了全新的社交体验。截至2020年,伊对App注册用户已达1亿,每月撮合线上相亲活动约1000万场,成为视频恋爱社交垂直领域最具影响力的品牌之一。

业务需求

随着伊对App业务的快速增长,核心应用的系统规模和系统复杂度也在经历着翻天覆地的变化。伊对App技术团队通过引进新的技术手段,维护整套系统架构的技术先进性,以更好地支持业务需求,降低IT成本。从成立以来,伊对App的核心系统架构完成了多次重大的升级,涉及微服务化、容器化、分布式数据库、大数据和人工智能等重要的技术,特别在Serverless技术的探索方面,伊对App投入了很大精力,以充分享受到云计算时代资源快速弹性伸缩的价值。

在伊对App的业务场景里面,视频直播是最为重要的环节,基于视频直播这个骨架,可以融入线上红娘等多类创新业务模式,这也对视频直播的内容安全提出了极高的要求。不论是自身通过AI技术对视频直播内容进行智能分析,还是应对监管的要求,都需要在每一路视频直播流开始后,根据固定频率对视频进行截帧,并通过统一的审核服务对截帧生成的图片进行处理。

在这个需求里面,截帧服务承担着关键职责,这个服务不仅需要通过FFmpeg命令对每一路直播视频流进行截帧操作,还需要将生成的图片保存到对象存储OSS,并将截帧信息写入到Kafka。这样下游的截帧服务就能从Kafka上拉取截帧信息,并从截帧信息中得到图片在OSS中的地址,从而完成对于图片的审核。在这个架构中,引入Kafka是为了通过异步处理机制缓解审核服务在业务高峰期的负载。

image.png

业务痛点

FFmpeg截帧命令使用非常简单,但这是一个对于CPU算力要求非常高的操作。根据伊对App技术团队的多次试验,采用ECS部署截帧服务,是一个相对成本最优的选择。如果按照每秒钟1次截帧的固定频繁,1台ECS能够同时支撑大约数百路直播视频流的截帧任务。为了保障业务高峰期的资源储备,伊对App准备了大量ECS来部署截帧服务。跟绝大多数互联网应用一样,伊对App的负载也存在着波峰波谷,这样的波动对伊对App整体的资源规划带来了极高的挑战,如果按照固定的ECS集群规模来部署截帧服务,会存在两个非常明显的弊端:

  1. 为了支持业务高峰,必须按照高峰期的用户量来评估集群规模,在业务低峰期就会造成巨大的浪费。
  2. 在某些场景下,比如节假日效应的带动,业务量会有突增,有可能需要对集群进行临时扩容,这种情况下往往扩容速度会滞后于业务流的增速,造成部分业务的降级处理。

为了节省资源成本,伊对App也探索过很多种弹性伸缩策略,比如通过弹性ECS实例配合容器化的方式部署应用,以实现集群规模能动态适配真实业务量的变化。但这些策略的实现都比较复杂,弹性伸缩能力都相对滞后。其中根本的原因是在传统的服务架构中,一个应用启动后都是长期保持运行的,在运行期间会并发会处理多个业务需求,不管业务量如何变化,这个应用占据的计算力都不会有本质的变化。

有没有一种直截了当的方式,可以在一路直播视频流开启后,拉起对应的计算力承接截帧任务,而在视频流关闭后,自动将计算力释放呢?这样的方式不需要应用实例长驻,可以实现真正的计算资源按需分配,也不需要借助额外的手段动态调整截帧服务的集群规模,是一种最为理想的方案。

作为云原生Serverless技术的代表,阿里云函数计算FC就正好实现了这样的思路。

函数计算FC有哪些独特之处?

阿里云自研的Serverless产品函数计算FC是事件驱动的全托管计算服务,完美契合了伊对App的需求和痛点。使用函数计算,用户无需采购与管理服务器等基础设施,只需编写并上传代码。函数计算会自动准备好计算资源,弹性地、可靠地运行任务,并提供日志查询、性能监控和报警等功能。借助函数计算FC,可以快速构建任何类型的应用和服务,并且只需为任务实际消耗的资源付费。

image.png

函数计算FC提供了一种事件驱动的计算模型,函数的执行是由事件驱动的。函数的执行可以通过函数使用者自己触发,也可以由其它一些事件源来触发。可以在指定函数中创建触发器,该触发器描述了一组规则,当某个事件满足这些规则,事件源就会触发相应的函数。比如对于HTTP触发起而言,用户的一次HTTP请求就能触发一个函数;而对于OSS触发器而言,OSS上新增或修改一个文件就能触发一个函数。在伊对App的视频截帧场景中,函数只需要在每一个直播流开始推送之前,通过业务程序主动触发一个截帧函数就可以了。因此之前截帧业务的架构只需要做很小的调整,就能迁移到函数计算平台上来,以享受Serverless的价值。

image.png

解决方案及优势

支持多种编程语言的Runtime

伊对App的技术团队第一次和阿里云沟通Serverless方案的时候,阿里云的技术人员推荐使用Python语言实现截帧函数,因为函数计算FC对于Node.js、Python、PHP、Java等语言提供了原生的运行环境,而且像Python这样的脚本语言可以实现在函数计算平台上直接修改调度代码,使用非常简单。其实函数计算FC对于开发语言没有要求,任何主流的开发语言都可以很好的支持。通过函数计算FC提供的Custom Runtime,可以为任务语言建立自定义的运行环境。Custom Runtime本质上是一个HTTP Server,这个HTTP Server接管了函数计算系统的所有请求,包括来自事件调用或者HTTP函数调用。

image.png

极致弹性和高可用性

由于在Serverless架构下,每一路直播视频流都会拉起新的计算资源来承接截帧任务,因此并不需要采用高规格的ECS实例同时并发处理多个截帧任务。通过反复的测试,伊对App采取了最适合的函数计算实例来完成每路视频流的截帧任务。

函数计算FC在计算资源的启动方面做了大量优化,配合云化的资源池,能够在100毫秒的时间内调度大量计算实例,以承载特殊情况下突增的业务流量。为了更进一步的适配伊对App的业务场景,阿里云函数计算团队还专门为伊对App提供了定时预热的方式,以最大程度的保障业务高峰期冷启动计算资源的性能。这样极致的弹性伸缩能力是Serverless的专长,传统的应用架构的弹性伸缩依赖于底层计算资源的调度,以及复杂的初始化工作,在计算实例的启动速度上远远达不到这个水平。

正常情况下,函数计算FC上一个普通弹性实例可运行时长为10分钟,此外还提供了性能实例,以应对更高的资源需求,性能实例在可运行时长上也提升到了数小时。在伊对App的截帧场景中,单实例并不需要有很高的性能,但有必要伴随着直播视频流长期运行,因此阿里云也为伊对App适当放开了弹性实例的运行时长限制:达到1小时。对于超过1小时的直播,同样可以支持:在截帧场景中,当一个函数实例将要达到运行时长限制的时候,只需要再拉起一个新的函数实例对截帧任务进行接力就可以了,对于截帧业务的正常运行不会有任何影响。

节省资源,降本增效

函数计算FC在实现计算资源按需调度,按量计费的同时,还通过预留实例的模型更进一步降低使用成本。根据初步的评估,在直播截帧这个业务场景上,通过基于函数计算FC的Serverless架构,能够帮助伊对App减少20%以上的资源成本开支。

image.png

此外,由于函数计算FC不需要预留计算资源,也不需要对底层的软硬件进行维护,极大程度的降低了运营成本,可以让伊对App的技术团队更专注在复杂业务逻辑的实现上。这也是Serverless技术为广大企业和开发者带来的巨大价值之一。

总结

在直播截帧场景试点Serverless技术成功后,伊对App继续在更多业务领域发掘Serverless技术的匹配场景。未来,伊对App将继续基于自身的技术特点不断深入探索Serverless架构,在拥抱新技术的同时也能充分享受到云计算的红利。

作者:阿里云解决方案架构师 山猎

推荐产品

函数计算FC https://www.aliyun.com/product/fc

扫码了解更多技术内容与客户案例:

公众号.png

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7月前
|
前端开发 Java 数据安全/隐私保护
计算机Java项目|基于Andriod技术“厕ce”APP
计算机Java项目|基于Andriod技术“厕ce”APP
|
2月前
|
机器学习/深度学习 监控 安全
量化合约对冲策略交易app系统开发技术规则
量化合约对冲策略交易APP系统开发技术规则涵盖系统架构设计、量化策略实现、交易管理、风险管理、用户界面设计及性能优化等方面。通过模块化设计、分布式架构、数据持久化、策略开发、算法交易、回测优化、订单管理、持仓监控、资金安全、风险控制、实时监控、安全审计、界面设计、反馈机制、多语言支持、响应速度、资源优化和兼容性等措施,确保系统的稳定、安全、高效和易用。
|
4月前
|
移动开发 Android开发 数据安全/隐私保护
移动应用与系统的技术演进:从开发到操作系统的全景解析随着智能手机和平板电脑的普及,移动应用(App)已成为人们日常生活中不可或缺的一部分。无论是社交、娱乐、购物还是办公,移动应用都扮演着重要的角色。而支撑这些应用运行的,正是功能强大且复杂的移动操作系统。本文将深入探讨移动应用的开发过程及其背后的操作系统机制,揭示这一领域的技术演进。
本文旨在提供关于移动应用与系统技术的全面概述,涵盖移动应用的开发生命周期、主要移动操作系统的特点以及它们之间的竞争关系。我们将探讨如何高效地开发移动应用,并分析iOS和Android两大主流操作系统的技术优势与局限。同时,本文还将讨论跨平台解决方案的兴起及其对移动开发领域的影响。通过这篇技术性文章,读者将获得对移动应用开发及操作系统深层理解的钥匙。
109 12
|
3月前
|
NoSQL PHP Redis
布谷语音app源码服务器环境配置及技术开发语言
布谷语音app源码服务器环境配置及技术语言研发。。
|
4月前
|
消息中间件 弹性计算 关系型数据库
体验函数计算:高效处理多媒体文件的真实感受与实战总结
该方案在引导和文档方面做得较为详尽,仅在事件驱动机制部分略显简略。部署和代码示例实用,但需注意内存配置以避免超时。使用体验方面,函数计算表现出色,尤其在高并发场景下,显著提升了应用稳定性和成本效益。云产品如OSS、MNS等与函数计算配合流畅,ECS和RDS表现稳健。总体而言,这套方案弹性好、成本低,特别适合应对高并发或流量不确定的场景,值得推荐。
80 24
|
3月前
|
Web App开发 编解码 视频直播
视频直播技术干货(十二):从入门到放弃,快速学习Android端直播技术
本文详细介绍了Android端直播技术的全貌,涵盖了从实时音视频采集、编码、传输到解码与播放的各个环节。文章还探讨了直播中音视频同步、编解码器选择、传输协议以及直播延迟优化等关键问题。希望本文能为你提供有关Andriod端直播技术的深入理解和实践指导。
60 0
|
6月前
|
存储 安全 数据安全/隐私保护
移动APP安全加固技术深度解析
【7月更文挑战第12天】移动APP安全加固技术是保障移动应用安全的重要手段。通过对Android和iOS两大主流平台的安全加固,可以有效防止逆向分析、动态调试、数据篡改等安全威胁。在实际应用中,我们需要结合静态层面、动态层面和数据层面的加固技术,全方位地提升APP的安全性。同时,随着技术的不断发展,我们也需要不断关注新的安全威胁和加固技术,确保移动应用的安全性和稳定性。
|
6月前
|
机器学习/深度学习 人工智能 文字识别
文本,文字扫描01,OCR文本识别技术展示,一个安卓App,一个简单的设计,文字识别可以应用于人工智能,机器学习,车牌识别,身份证识别,银行卡识别,PaddleOCR+SpringBoot+Andr
文本,文字扫描01,OCR文本识别技术展示,一个安卓App,一个简单的设计,文字识别可以应用于人工智能,机器学习,车牌识别,身份证识别,银行卡识别,PaddleOCR+SpringBoot+Andr
|
7月前
|
存储 安全 前端开发
APP管理后台OSS技术改造
旨在记录之前使用的上传文件是放在服务器的现在改成了oss更加高效管理
|
6月前
|
小程序 API
跨端技术问题之哪些形态可以通过getApp()获取全局App实例
跨端技术问题之哪些形态可以通过getApp()获取全局App实例

相关产品

  • 函数计算