首页 > 解决方案 > 如何确保一次只运行一个 Azure Function BlobTrigger?

问题描述

我有一个在 Azure Functions 中实现多个 BlobTriggers 的用例(使用 Linux 消耗计划)。例如,在 Azure 存储中,我将有 5 个不同的客户端,其目录结构如下:

client1/file.txt  
client2.file.txt  
client3/file.txt  
client4/file.txt  
client5/file.txt

在 Azure 存储中,两者client1/file.txt和可能同时client2/file.txt被丢弃。为了防止竞争条件和超过 1.5 GB 内存限制,我希望 BlobTrigger forclient1/file.txt等待 BlobTrigger forclient2/file.txt完成,反之亦然(这里的顺序无关紧要,只是它们最终都会执行)。

我必须单独设置队列进程吗?我可以使用预览设置WEBSITE_MAX_DYNAMIC_APPLICATION_SCALE_OUT轻松实现这一点吗?

编辑:使用持久功能会是更好的解决方案吗?

标签: azureazure-functionsazure-storageazure-blob-storage

解决方案


您应该能够通过确保将 MAX SCALE OUT 值设置为 1 来做到这一点,这样它一次只会处理 1 个文件。您还可以将消费\定价模型从消费更改为应用服务计划一。通过这种方式,您可以使用所需的层,然后您也可以获得更多可用内存(取决于您选择的层)。


推荐阅读