您好,我了解,如果我创建一个由队列中的消息触发的 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/