- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我使用以下代码:
创建重试策略,当出错时,1秒后重试,然后等待3秒,然后5秒。基于Azure SLA,10秒内重试必须成功(没有限制,我确信这一点。因为错误甚至发生在还没有流量的唯一分区和表上)
var retryStrategy = new Incremental(3, TimeSpan.FromSeconds(1), TimeSpan.FromSeconds(2));
var FaultHandlingRetryPolicy = new RetryPolicy<StorageTransientErrorDetectionStrategy>(retryStrategy);
然后我使用这段代码来获取数据
FaultHandlingRetryPolicy .ExecuteAction(() =>
{
var results = (from q in Query select new q).ToList();
});
我不知道是否重试,因为错误日志未显示
错误:
System.Net.WebException: Unable to connect to the remote server ---> System.Net.Sockets.SocketException: No connection could be made because the target machine actively refused it 70.37.127.112:443
at System.Net.Sockets.Socket.DoConnect(EndPoint endPointSnapshot, SocketAddress socketAddress)
at System.Net.ServicePoint.ConnectSocketInternal(Boolean connectFailure, Socket s4, Socket s6, Socket& socket, IPAddress& address, ConnectSocketState state, IAsyncResult asyncResult, Int32 timeout, Exception& exception)
--- End of inner exception stack trace ---
at System.Net.HttpWebRequest.GetResponse()
at System.Data.Services.Client.QueryResult.Execute()
at System.Data.Services.Client.DataServiceRequest.Execute[TElement](DataServiceContext context, QueryComponents queryComponents)
at System.Data.Services.Client.DataServiceQuery`1.Execute()
at System.Data.Services.Client.DataServiceQuery`1.GetEnumerator()
at System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)
at System.Linq.Enumerable.ToList[TSource](IEnumerable`1 source)
at Microsoft.Practices.TransientFaultHandling.RetryPolicy.<>c__DisplayClass1.<ExecuteAction>b__0()
at Microsoft.Practices.TransientFaultHandling.RetryPolicy.ExecuteAction[TResult](Func`1 func)
请告诉我此代码是否会重试,谢谢
最佳答案
当您设置重试策略时,您可以指定控制退出的类,在您的情况下,它是 StorageTransientErrorDetectionStrategy
。
每次在ExecuteAction()
方法中抛出异常时,此类将决定是否可以重试。例如,某些异常是暂时的,因此不值得重试。
要实际跟踪重试次数,您可以使用如下代码:
FaultHandlingRetryPolicy.Retrying += (obj, eventArgs) =>
{
Console.Writeline("Retrying, CurrentRetryCount = {0} , Exception = {1}", eventArgs.CurrentRetryCount, eventArgs.LastException.Message);
};
更新
您可以像这样创建自己的错误处理策略并使用它来代替标准策略。 但是你必须调整错误以适应你的场景,这些对我有用。
public class CustomSqlAzureTransientErrorDetectionStrategy : ITransientErrorDetectionStrategy
{
private readonly SqlAzureTransientErrorDetectionStrategy _normalStrategy =
new SqlAzureTransientErrorDetectionStrategy();
public bool IsTransient(Exception ex)
{
if (_normalStrategy.IsTransient(ex))
return true;
//do our custom logic
if (ex is SqlException)
{
var sqEx = ex as SqlException;
if (sqEx.Message.Contains("The timeout period elapsed prior to completion of the operation or the server is not responding") ||
sqEx.Message.Contains("An existing connection was forcibly closed by the remote host") ||
sqEx.Message.Contains("The service has encountered an error processing your request. Please try again") ||
sqEx.Message.Contains("Timeout expired") ||
sqEx.Message.Contains("was deadlocked on lock resources with another process and has been chosen as the deadlock victim") ||
sqEx.Message.Contains("A transport-level error has occurred when receiving results from the server"))
{
return true;
}
}
return false;
}
}
关于c# - Microsoft.Practices.TransientFaultHandling.RetryPolicy 的正确代码是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9904588/
在我的项目中,我使用了某种由外部团队编写的 SDK 库。这些图书馆正在使用 Prism。由于某些原因,我们不得不回滚到他们的 SDK 的以前版本,现在构建失败,试图找到对 Microsoft.Prac
我是基于 MVVM 的单元测试应用程序,它使用 prism 并使用模拟来测试 View 模型。我可以通过传递区域管理器和资源管理器的模拟对象来调用我的 viewmodel 类的构造函数,但是当控制进入
我需要将名为“practice”的列插入到表“cred_insurances”中,该表是一个 FK 引用表“practices” PK “id” 最佳答案 您需要通过在 mysql 提示符下运行以下命
我创建了一个项目来练习将 Git 与 Xcode 和 GitHub 结合使用。经过大量工作,我已经在本地和远程创建了存储库。我刚刚尝试提交并收到此错误: 这是我要 promise 的: 在出现此错误之
我正在考虑使用 DTO 而不是传递我的域对象。我在这里和其他地方都读过几篇文章,我知道有几种方法可以完成这项工作。 如果我总共只有大约 10 个域类,并且考虑到我想在我的 View (WPF 前端)中
我想知道 Django Rest Framework 的最佳实践。我一直通过每个用户使用不同的序列化程序(员工、帐户所有者、其他人)和 HTTP 方法来限制更改帐户上某些属性的访问权限,但我觉得这太不
场景:应用程序具有可以启用某些优化的算法。默认情况下,有些是打开的,有些是关闭的。在 Java 中是否有一种方便的方法来实现某种全局属性系统? 要求: 必须很容易两次使用不同的设置运行程序的多个实例
我的代码如下: public static final Condition.ActionCondition ACTION_CONDITION_ACTIVATE = new Condit
我从事嵌入式工作,我有一些管理硬件的软件模块。这个模块有状态,状态转换很复杂:根据事件,模块可以从状态 A 到状态 B 或者可能到 C .但是,当它退出某个状态时,它应该对硬件执行一些操作,以使其也保
考虑 an^2 + bn + c。我知道对于大的 n,bn 和 c 变得微不足道。 我还了解到,对于较大的 n,2n^2 和 n^2 之间的差异非常微不足道 n^2 和 n*log(n) 之间的区别。
我正在设计一个数据库并且我达到了(据我所知)Third Normal Form (3NF) 我的一些同事告诉我一个 Sixth Normal Form !!我想知道如何知道数据库的规范化水平是否足够。
我有一个.net 3.5网站,该网站使用Microsoft.Practices.EnterpriseLibrary调用数千个不同的存储过程。 我们已经遇到了很多超时,并且在播放和测试表末尾的(nolo
我使用 nuget 包管理器添加了最近的企业库,但在部署时(而不是在构建时)仍然低于错误。 包管理器:Install-Package EnterpriseLibrary.Data 谁能帮我 命名空间“
我一直在阅读关于版本控制主题的所有问题,但我认为我没有找到一个看起来像我自己的场景。 场景是: 我们有一个中型/大型 Web 应用程序,它有(至少应该有)一个部署到所有客户端的核心。当我们向客户演示应
很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visit the help center . 8年前关闭
代码 (Java) 片段 ..... ..... if ( response.check() == checkNumber ) { String message = "You ar
我刚刚开始在我的(Delphi)应用程序中使用异常记录器(EurekaLog)。现在,我的应用程序每天都会通过电子邮件向我发送大量错误消息。这是我迄今为止发现的内容 大量重复错误 来自同一台电脑的多封
我想收集有关我的代码的特定例程的指标,以了解可以最好地优化的地方。让我们举一个简单的例子,假设我有一个包含多个“学生”的“类(class)”数据库。假设当前的代码为每个学生调用数据库,而不是一次性批量
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 2 年前。 Improv
我正在尝试加快查询速度。其中很多都非常复杂,目前我主要通过创建多个查询并通过联接链接它们来实现这一点。 这是最佳实践吗?还是我应该在 SELECT 中使用 SELECT 并尝试在一个查询中实现相同的目
我是一名优秀的程序员,十分优秀!