我有一个运行在Azure + Bot Framework + LUIS(通过LuisDialog)的机器人。
如果用户碰巧快速连续发送两条消息(在机器人有机会回答之前),他们会在Facebook Messenger或web embed上看到此错误消息:
对不起,我的机器人代码有问题。
通过bot通道模拟器进行调试时,我发现错误是这样的:
“text”:“错误:响应状态代码未指示成功:429(请求太多)。在System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务)处于System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) Microsoft.Bot.Builder.Luis.LuisService.d__4.MoveNext()
堆栈跟踪的结尾显示错误源自MessageController.cs中的此行:
await Conversation.SendAsync(activity, () => new LuisRootDialogEnglish());
这很奇怪,因为我使用的是付费版本的LUIS,每秒最多可以拨打10个电话。
在任何情况下,我都尝试将MessageController.cs中的整个代码包装到try/catch
块中,并且无论异常如何都返回此值:
return Request.CreateResponse(HttpStatusCode.OK);
仍然,用户看到错误消息“抱歉,我的机器人代码有问题”,这基本上意味着存在未处理的异常。
如何防止向用户显示此消息或捕获异常?
该消息仅在PostUnhandledExceptionToUserTask
中发送给用户,因为异常已转义根对话框A.您可以通过防止未处理的异常转义根对话框A来避免这种情况。
一个选项是添加一个不同的根对话框B,只需调用对话框A,然后忽略传递给IAwaitable<R>
回调的ResumeAfter<R>
结果。
Chain.DefaultIfException
提供了对话框B的实现。
您可以使用Bot Framework的DefaultIfException
功能来内部处理异常。
它看起来像这样:
await Conversation.SendAsync(
activity, () => new Dialogs.RootDialog().DefaultIfException()
);
当你得到403或429时,它可能分别是“超出配额”或“太多请求”,在第一种情况下,你必须再次创建一个密钥并与你的LUIS应用程序对齐,前1000个端点查询是免费的,它将每月刷新,你必须明智地使用它,或者你必须使用付费层。
对于第二种情况,您还有一个请求限制,请参阅Boundaries documentation
在这里您可以找到Microsoft documentation。