Azure函数-写入表输出绑定时处理错误

时间:2019-04-08 05:39:42

标签: javascript azure azure-functions

我有一个Azure功能设置。其触发器设置为服务总线队列消息。触发功能后,将以某种方式处理消息。如果在处理过程中遇到任何异常,我将处理该错误,并将消息保存在Azure表存储集中作为输出绑定,以进行记录。

我想处理在向输出绑定中写入内容时引发的所有错误。我将如何去做?

错误的详细信息

在写输出绑定(表存储)期间遇到的错误之一是某些键的值无法保存。例如消息中的键之一是time,其值类型为 number 。写入此数据时,我得到一个例外,即密钥的值不能适合Int32数字。我认为表存储尝试默认将数字转换为Int32,但失败了。要解决此问题,我将所有键都转换为具有字符串值。现在我可以保存。

但是我仍然想在写入表存储输出绑定时处理所有不可预见的错误。

在这种情况下,处理错误很重要,因为如果未正确使用服务总线消息,则不会在服务总线队列中删除该消息,并且在执行Azure函数后,该消息会再次触发函数,并且Function进入不确定的循环。

以下是Azure函数的示例

module.exports = async function (context, mySbMsg) {
    try{
        // process service bus message
        await processMsg(mySbMsg);
    } catch(e) {
        // if processing fails, save the message in Azure table
        try{
            // my own try to handle errors, but was unsuccessful
            await new Promise(function (resolve, reject) {
                context.bindings.tableBinding = [];
                context.bindings.tableBinding.push({
                    PartitionKey: mySbMsg.id|| "unknown",
                    RowKey: time + "",
                    errorMessage: e.message || "",
                    ...mySbMsg
                })
                resolve();
            });
        } catch (e) {
            // do something HERE;
            // exception on output binding didn't brought me here
        }
    }
    context.done();
}

1 个答案:

答案 0 :(得分:2)

输入和输出绑定在函数范围之外执行,这就是为什么您不能在函数内输入catch块的原因。如果您想捕获错误,则可以自行处理写入存储,而不用使用输出绑定。

但是,如果您无法写入存储,则服务总线队列将不会在无限循环中触发该功能。服务总线限制了重试次数,一旦达到该限制,邮件就会移到单独的死信队列中,以避免无限循环。其中的邮件不会过期-它们将一直放置在那里,直到您准备好处理或删除它们为止。

enter image description here

默认的最大投放次数是10,您可以在队列的属性刀片上配置该次数。

就处理死信队列中的消息而言,我发现Service Bus Explorer很有帮助。可以很容易地查看DLQ中的消息,然后将它们推回主队列或删除它们。

您还可以通过编程方式访问DLQ并构建自动系统来处理这些消息。但是,由于消息无处可去,因此如果您的DLQ处理程序无法解析消息,您可能会陷入循环。