azure - 以编程方式停止 azure 函数

标签 azure azure-functions

您好,我了解,如果我创建一个由队列中的消息触发的 azure 函数,如果队列中有多个消息,则可以(水平)扩展。换句话说,同一 azure 函数的多个实例可以运行来处理队列中的消息。

我还知道在 azure 函数中我可以获取正在运行的实例的 ID。 假设当我的 azure 函数的实例启动时,我将正在运行的实例的 ID 存储在数据库中。

现在,我的问题是,如何以编程方式停止/终止我的 azure 函数的特定实例(由存储的 ID 标识)?

提前致谢!!

场景

我有一个供我的用户使用的仪表板。他们可以在其中创建任务。创建任务后,定义将与用户 ID 作为消息一起进入队列。一旦消息在队列中可用,就会触发 azure 函数。现在,当用户刷新仪表板时,她/他会看到任务列表(由他/她创建),无论任务正在运行还是已完成。我现在还需要给他们一个停止正在运行的任务的选项。

现在,多个用户可以创建具有不同参数的任务,并在同一队列中发送多个消息,这将导致运行同一 azure 函数的多个实例。每个实例都与特定用户绑定(bind)。如果用户选择停止任务(这是同一个 azure 函数的实例),我需要停止 azure 函数的特定实例(与禁用整个 azure 函数不同)。现在我所知道的有关正在运行的实例是 ID ,我想知道是否可以从代码中停止/终止/取消该特定函数实例。

我希望我成功地解释了我的情况。如果您有更多问题,请告诉我。

最佳答案

今天没有办法做到这一点。即使您要终止一个实例,Functions Scale Controller 也可能会发现您需要更多实例进行处理,并为您启动另一个实例。

最好充分理解这里的场景——您是否试图限制横向扩展?或者停止个别失控的功能?

编辑:阅读您的场景后,您是否了解过耐用功能?您应该能够基于队列消息启动编排并使用 OrchestrationClient 管理它们。需要注意的是,事件函数一旦启动就无法取消,但如果您充分分解步骤,您将能够终止进程内编排。请参阅此处了解更多详细信息:

关于azure - 以编程方式停止 azure 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53198248/

相关文章:

python - 如何通过 Python 从 Azure Functions 连接到 Azure MySQL

sql - 如何授予 Select 访问权限以在架构中查看

azure - Azure 是否会运行我的辅助角色的 2 个实例?

适用于逻辑应用的 Azure API 管理反向代理

Azure Functions 连接到本地 SQL Server

azure - 需要 Blob 触发器 Azure Function 才能仅响应 BLOB UPLOAD

azure - .NET Azure Functions 中的依赖项注入(inject) - Azure Cosmos DB 客户端

c# - Azure Functions 环境变量始终为 null

api - 如何使用 RBAC API 获取所有角色分配的列表

azure - Windows Azure 诊断错误 :