【译】Serverless架构 - 4

本文涉及的产品
简介: 原文: https://martinfowler.com/articles/serverless.html状态当使用本地(机器/实例绑定)状态时FaaS函数有很严格的限制。

原文:

https://martinfowler.com/articles/serverless.html

状态

当使用本地(机器/实例绑定)状态时FaaS函数有很严格的限制。简单说,你应该假设对于任何函数调用,你创建的进程内或主机状态都不会对后续任何调用生效。这状态包括内存和要写入到本地磁盘的。换句话说从部署单元的角度看FaaS函数是无状态的。

这对应用架构有极大影响,尽管不是唯一的因素 - ‘12因子应用’概念有同样的限制 http://12factor.net/processes

这个限制有什么可以代替的?正常来说表示要么FaaS函数是天生无状态 - 他们对输入提供纯函数变换 - 要么他们使用数据库, 跨应用缓存(如Redis),或网络文件存储(如S3)将跨请求的状态存储起来以备后续的处理请求时需要用来做输入。

执行周期

FaaS函数通常受限于每次调用可以允许运行的时间。目前AWS Lambda函数不允许运行超过5分钟,如果超过会被终止。

这意味着某些长执行周期的类如果不进行重构是不适合在FaaS函数中运行的,比如你可能需要创建很多不同的FaaS函数协调器,在传统环境中你可能只有一个有一个长周期的任务同时做协调和执行。

启动延迟

目前你的FaaS函数需要多长时间响应请求取决于很多因素,可能会在10ms到2分钟。这听起来很糟,但让我们具体点,用AWS Lambda作为例子。

如果你的函数不大(少于一千行代码)并用Javascript或Python实现,那么运行的开销应该不会超过10-100ms。更大的函数可能会要更长的时间。

如果你的函数使用JVM上的实现当JVM启动时你可能偶尔会看到较长的响应(大于10秒)。但是这只会发生在以下场景:

  • 你的函数进程不经常处理时间,调用的时间间隔大于10分钟。
  • 你的流量出现高峰,比如正常你每秒处理10个请求但突然在10秒内每秒100个请求出现。

这些情况可以用比较丑陋的技巧 - 每5分钟ping以下你的函数保证它的存活来解决。

这些问题是否值得关注?这取决于你应用的流量图形。我的前团队有一个用Java实现的Lambda用来处理亿级异步消息/天,他们不关心启动延迟。这说明如果你要写一个低延迟的交易引用你肯定不会想使用FaaS系统,无论你用什么语言实现。

无论你觉得你的应用是不是有这个问题,你应该用生产环境的负载来测试实际性能。如果你的case现在还不行,你可以在几个月后再测试一下,因为这是FaaS供应商的主要开发领域。

相关实践学习
基于函数计算一键部署掌上游戏机
本场景介绍如何使用阿里云计算服务命令快速搭建一个掌上游戏机。
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
目录
相关文章
|
9天前
|
运维 安全 Serverless
Serverless架构在图像处理中的优势探讨
Serverless架构在图像处理中的优势探讨
16 1
|
1天前
|
弹性计算 安全 Serverless
图像处理场景下的Serverless架构
【4月更文挑战第15天】图像处理场景下的Serverless架构
|
3天前
|
人工智能 Serverless 数据处理
利用阿里云函数计算实现 Serverless 架构的应用
阿里云函数计算是事件驱动的Serverless服务,免服务器管理,自动扩展资源。它降低了基础设施成本,提高了开发效率,支持Web应用、数据处理、AI和定时任务等多种场景。通过实例展示了如何用Python实现图片压缩应用,通过OSS触发函数自动执行。阿里云函数计算在云计算时代助力企业实现快速迭代和高效运营。
3 0
|
4月前
|
运维 Serverless API
四大软件架构:掌握单体、分布式、微服务、Serverless 的精髓
如果一个软件开发人员,不了解软件架构的演进,会制约技术的选型和开发人员的生存、晋升空间。这里我列举了目前主要的四种软件架构以及他们的优缺点,希望能够帮助软件开发人员拓展知识面。
|
30天前
|
敏捷开发 jenkins Serverless
Serverless 应用架构转型
【2月更文挑战第29天】
|
1月前
|
机器学习/深度学习 人工智能 Serverless
20行代码,Serverless架构下用Python轻松搞定图像分类和预测
本文将AI项目与Serverless架构进行结合,在Serverless架构下用20行Python代码搞定图像分类和预测。
111763 126
|
3月前
|
机器学习/深度学习 弹性计算 Serverless
引领未来科技发展的无服务器架构(Serverless)
无服务器架构(Serverless)是一种革命性的云计算模式,它将开发者从传统服务器管理的繁琐中解放出来,提供了更高效、灵活和可扩展的应用开发和部署方式。本文将介绍无服务器架构的概念、原理及其在各个领域的应用,并展望其对未来科技发展的巨大影响。
|
3月前
|
存储 物联网 Serverless
无服务器架构(Serverless)的革命性应用
无服务器架构是一种全新的云计算模型,它将传统的基于服务器的架构转变为以事件驱动的、按需自动化的架构。本文将探讨无服务器架构的定义、特点以及在现代应用开发中的应用。
151 2
|
4月前
|
运维 Cloud Native Serverless
MSE Serverless 正式商用,构建低成本高弹性的微服务架构
MSE Serverless 正式商用,构建低成本高弹性的微服务架构
70476 77
|
4月前
|
Cloud Native 安全 Serverless
阿里云重磅亮相信通院 2023 云原生产业大会,持续推动 Serverless 架构落地 | 报名启动
阿里云重磅亮相信通院 2023 云原生产业大会,持续推动 Serverless 架构落地 | 报名启动

相关产品

  • 函数计算