用于在运行之间存储函数应用状态的 Azure 持久实体 (.net 6)
Posted
技术标签:
【中文标题】用于在运行之间存储函数应用状态的 Azure 持久实体 (.net 6)【英文标题】:Azure Durable Entity for storing function app state between runs (.net 6) 【发布时间】:2022-01-07 06:14:24 【问题描述】:我想每分钟运行一个简单的 .net 6 c# 消费 azure function app(不持久),但我需要记住上次运行的状态。
状态由 json 可序列化对象数组和一些访问令牌字符串组成。
所以我创建了一个这样的持久函数实体:
[JsonObject(MemberSerialization.OptIn)]
public class DurableStorageEntity
[JsonProperty("simpledata")]
public string SimpleData get; set;
[JsonProperty("complicateddata")]
public List<ComplicatedObject> ComplicatedData get; set;
public void SetSimpleData(string data) => this.SimpleData = data;
public void SetComplicatedObject(List<ComplicatedObject> data) => this.ComplicatedObject = data;
[FunctionName(nameof(DurableStorageEntity))]
public static Task Run([EntityTrigger] IDurableEntityContext ctx)
=> ctx.DispatchAsync<DurableStorageEntity>();
这很好用,但我不确定它的效率如何,以及我可以通过这种方式存储多少状态数据。经过测试,我也不确定从常规(即非持久)函数应用调用时这是否可靠。
我找不到任何明确的信息。在MS document on Entity Functions 中,它只是声明:
实体函数定义用于读取和更新小块状态的操作,称为持久实体。
和
实体提供了一种扩展应用程序的方法,方法是将工作分布在许多实体中,每个实体都具有适度大小的状态。
所以这让我不确定我可以存储多少数据。我通常会存储几个数组,每个数组有几百个项目,每个对象由字符串、整数和日期组成。如果有更好的方法在运行之间存储状态,那么欢迎使用替代方法,但我确实喜欢使用这些实体函数,所以我希望它是一个可行且可靠的选择。
12 月 2 日更新:
我一直在测试使用 100 项对象数组(字符串、整数、日期时间)存储对象列表。
我在我的机器上本地运行它。我可能做错了什么,但偶尔它会返回我之前存储的旧数据,而不是持久实体存储中存储的最新数据。我不确定为什么会这样。我可以通过存储大量数据来实现它,但它也可以在其他时间随机发生。
生成 100 个对象 大小:6 365 853 字节 读取时间:250ms 写入时间:215ms
生成 1000 个对象 大小:63 658 851 字节 读取时间:2s 659ms 写入时间:1s 811ms
生成 10000 个对象 写入似乎成功,但读取时获得了之前的 1000 个对象
生成 10 个对象 按预期回读 10 个对象
生成 2000 个对象 错误:仍然得到 10 个对象
生成 1000 个对象 错误:仍然得到 10 个对象
生成 100 个对象 错误:仍然得到 10 个对象
生成 1 个对象 终于按预期取回了 1 个对象
生成 10 个对象 错误:三次运行仍获得 1 个对象,但在函数应用程序的第四次运行时突然获得 10 个对象。
这是在我的本地机器上,win10、i7、32Gb RAM,并且在 VS2022 中没有调试器。
【问题讨论】:
【参考方案1】:当reading entity state 在持久函数中时,它会尝试读取实体的当前状态。如果实体不存在,或者实体的 JSON 序列化状态大于 16KB,则返回 undefined。
Azure 持久实体/函数也按正常存储帐户成本计费,用于存储和事务到表和队列。 https://docs.microsoft.com/en-us/azure/azure-functions/durable/durable-functions-billing
在我的一个函数应用程序中,持久实体似乎并不适用于存储在表存储中的
我听说size of blob 已从 5TB 增加到 200TB。一些可能具有限制性的限制。
表实体的最大大小为 1MB,就内存消耗而言,计划有 1.5 GB 的限制,而其他计划有 3.5-14 GB)。我猜想天蓝色函数内存限制将是实体的限制大小。
这些点在这里也很重要,例如:
实体情况下的存储大小限制与如何 我们可以将大量数据放入 Azure 表存储。我不认为我们有 使用门槛。
根据定价模型,Azure 函数根据内存收费 大小、执行时间和每月执行。
【讨论】:
在我看来,这是我之前在 *** 和各种 MS 文档中看到的模糊相关材料的集合,但没有进一步说明此事。以上是关于用于在运行之间存储函数应用状态的 Azure 持久实体 (.net 6)的主要内容,如果未能解决你的问题,请参考以下文章
Azure Web Apps For Containers 持久存储
将值从 Azure 逻辑应用程序传递到 HttpTrigger Azure 函数
Blazor webassembly pwa 会话存储在部署到 Azure 后不持久
在 Azure 持久函数上调用 CreateCheckStatusResponse 时,Azurite 未给出与 Azure 存储模拟器相同的结果