用于在运行之间存储函数应用状态的 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 存储模拟器相同的结果

Azure 函数状态码 500 内部服务器错误

Azure 函数访问存储帐户