Too many querIEs per second
要么
Server Busy
一般来说,由于我有许多REST服务要调用,我怎么能一般地处理发生异常时会发生的退避逻辑呢?
有没有内置的框架?我只是想编写干净的代码,不要太担心管道和基础设施.
解决方法 您可以在一个处理重试逻辑的方法中将尝试包装起来.例如,如果您使用的是WebClIEnt的异步方法:public async Task<T> Retryquery<T>(Func<Task<T>> operation,int numberOfAttempts,int msecsBetweenRetrIEs = 500){ while (numberOfAttempts > 0) { try { T value = await operation(); return value; } catch { // Failed case - retry --numberOfAttempts; } await Task.Delay(msecsBetweenRetrIEs); } throw new ApplicationException("Operation Failed repeatedly");}
然后你可以通过以下方式使用:
// Try 3 times with 500 ms wait times in betweenstring result = await Retryquery(async () => webClIEnt.DownloadStringTaskAsync(url),3);总结
以上是内存溢出为你收集整理的发生异常时,如何处理C#应用程序中的退避或“等待和重试”逻辑?全部内容,希望文章能够帮你解决发生异常时,如何处理C#应用程序中的退避或“等待和重试”逻辑?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)