gpt4 book ai didi

azure - azure 函数上的 TaskCanceledException(服务总线触发器)

转载 作者:行者123 更新时间:2023-12-05 07:32:11 25 4
gpt4 key购买 nike

我有一个服务总线触发器 Azure 函数,每次主题收到消息时都会触发该函数。消息定期到达,例如每 30 分钟一次。批处理之间没有事件。

该函数没有做任何特殊的事情,它通过 HttpClient 异步发布消息。该函数定期因 TaskCanceledException 而停止。

HttpClient 是静态的

public static class SampleEventTrigger
{
private static DefaultHttpWebHook webHook = new DefaultHttpWebHook(new Uri("https://nonexistent.invalid/sampleWebHook"), "/event/sampleEvent");

[FunctionName("SampleEventTrigger")]
public static async Task Run(
[ServiceBusTrigger("sampleevent", "SampleEvent.Subs", AccessRights.Manage, Connection = GlobalConfiguration.ServiceBusConnection)]BrokeredMessage message,
TraceWriter log)
{
log.Info("launch sample event subscription");

try
{
var resp = await webHook.Post(message, log);
log.Info($"{resp.StatusCode}, {resp.ReasonPhrase}");
}
catch (Exception ex)
{
log.Error($"exception in webhook: {ex.Message}", ex);
throw;
}
}
}

如果我之后再次提出,这次就过去了。这个异常从何而来?我们如何避免这种情况?是否与超时有关,或者与启动太慢的功能有关?

我的函数处于消耗模式。

最佳答案

您的 Http 调用很可能超时。等待的 Http 调用超时会抛出 TaskCanceledException 。我不确定您的 DefaultHttpWebHook 类在幕后做了什么,但它应该使用 PostAsyncPost 方法 ( which itself should have the Async suffix ) 中。

验证您是否可以捕获 TaskCanceledException 并检查内部异常。如果您仍然遇到困难,请在本地开发期间将代码转换为非异步,以便更好地处理正在发生的情况 - 它会给您返回一个真正的异常,而不是将其作为 TCE 冒泡。

关于azure - azure 函数上的 TaskCanceledException(服务总线触发器),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51423250/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com