我正在开发一个使用Elasticsearch .NET客户端库(Elasticsearch.Net和NEST)的应用程序,作为从Elasticsearch 1.x到2.x转换的一部分,我正在尝试制定2.x等效于以前通过IElasticSearchResponse
公开的某些数据。
在1.x实现中,我们在提供给ConnectionSettings.SetConnectionStatusHandler()
的方法中执行了以下逻辑:
private static void LogElasticSearch1DotXMetrics(IElasticsearchResponse resp)
{
if (resp.NumberOfRetries > 0)
PerformSomeLoggingOperationOn(resp.NumberOfRetries);
}
我相信在2.x中,等效于
ConnectionSettings.SetConnectionStatusHandler()
的方法是将方法传递给ConnectionSettings.OnRequestCompleted()
。该方法将接收一个IApiCallDetails
实例。 private static void LogElasticSearch2DotXMetrics(IApiCallDetails details)
{
PerformSomeLoggingOperationOn(details.??????);
}
我无法在
IElasticSearchResponse.NumberOfRetries
上找到明显的IApiCallDetails
等效项。谁能指出我正确的方向?
最佳答案
我将这个问题提供给Elasticsearch支持,并在这里总结他们的回答,以防其他人觉得有用。
在Elasticsearch.NET 2.x中没有与NumberOfRetries直接等效的功能。但是,在达到最大重试次数的情况下会发生事件。
var maxRetriesReached = callDetails.AuditTrail
.Any(a => a.Event == AuditEvent.MaxRetriesReached);
另外,如果您真的对重试次数感兴趣,而不是是否放弃查询,则还可以观察BadResponse事件的审核记录。
var badResponses = callDetails.AuditTrail
.Any(a => a.Event == AuditEvent.BadResponse);
关于elasticsearch - 什么是IElasticSearchResponse.NumberOfRetries的Elasticsearch.Net 2.x等效项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38602670/