认识与设计Serverless(二)

一、设计Serverless的功能模块

  第一节讲了Serverless一些概念与特性,废话居多,概念的东西了解过后要有设计与构思,才能学到精髓,一个Serverless平台的形成,涉及到很多模块的架构与搭建,是需要精兵的开发团队才能完成的工作,一个Serverless开发平台涉及的功能模块,大概如下图设计

  

二、Serverless流程架构设计

  Serverless平台函数的运行,需要依赖于第三方平台管理的服务器以及运行时需要的众多能实时拉取的容器,所以成本是比较高的,财力人力物力兼具的大公司,如下展示的是具备以上能力的团队可以考虑的Serverless平台架构方案,以及不具备以上能力时的穷逼架构设计。

  土豪版:

  用户将开发完成的函数在IDE中保存,代码被存入S3中,用户对函数发起请求时,将请求路由至Serverless管理器中,根据请求的函数从S3中拉取代码,同时拉取一个容器,部署代码,制作镜像,之后启动容器和运行函数,在此过程中,一个函数对应的部署到一个容器中,容器有冷启动和热启动时间,在经过冷启动后,热启动的时间对请求的消耗是能够接受的,但需要有专业的容器管理团队支持。

  

  穷逼版:该方案可以摆脱对容器的依赖,最大化的节约成本,首先在一个VM中部署多个容器,并将容器的IP和端口分配给用户,用户开发完代码后将代码保存在S3,并生成代码对应的uuid,之后发布函数,发布的时候,会将uuid和对应的发布的函数请求url维护在一个路由配置中,同时根据事先分配给用户的IP和PORT将函数发布到对应的Runtime(以Restful的形式暴露),当用户请求时,首先根据请求的url在路由配置中找到代码的uuid,之后经过网关路由到对应的Runtime,Runtime有个前拦截,将传递过来的uuid在S3中找到对应的代码,利用虚拟的代码执行器运行代码,并将获得的结果返回。

  

posted @   纪煜楷  阅读(294)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示