AWS CloudWatchLogs 不使用DescribeLogStreamsRequest 按降序返回日志
我正在使用 C# AWS SDK 以(日期时间)降序顺序(最新优先)检索 CloudWatch 日志。因此,按如下方式设置 AmazonCloudWatchLogsClient
:
AmazonCloudWatchLogsConfig config = new AmazonCloudWatchLogsConfig {
RegionEndpoint = Amazon.RegionEndpoint.GetBySystemName("<aws-region>")
};
AmazonCloudWatchLogsClient _client = new AmazonCloudWatchLogsClient(config);
_client.DescribeLogStreamsAsync(new DescribeLogStreamsRequest {
LogGroupName = "logGroup",
OrderBy = "LastEventTime",
Descending = true,
});
并按如下方式设置云监视组和流:
_client.CreateLogGroupAsync(new CreateLogGroupRequest { LogGroupName = "logGroup" });
_client.CreateLogStreamAsync(new CreateLogStreamRequest {
LogGroupName = "logGroup",
LogStreamName = "logStream"
});
比按如下方式检索云监视日志:
var request = new GetLogEventsRequest
{
LogStreamName = "logStream",
LogGroupName = "logGroup",
StartTime = DateTime.UtcNow.AddDays(-1),
EndTime = DateTime.UtcNow,
Limit = 50,
StartFromHead = false
};
var response = await GetLogEventsAsync(123, 456, 50, "000/f", "000/b");
var logs = response.Events;
一如既往地接收 日志
最旧的优先,而不是最新的优先。
请提出任何修复建议。
I am using C# AWS SDK to retieve CloudWatch logs in (date-time) descending order (latest-first). So setting up the AmazonCloudWatchLogsClient
as follows:
AmazonCloudWatchLogsConfig config = new AmazonCloudWatchLogsConfig {
RegionEndpoint = Amazon.RegionEndpoint.GetBySystemName("<aws-region>")
};
AmazonCloudWatchLogsClient _client = new AmazonCloudWatchLogsClient(config);
_client.DescribeLogStreamsAsync(new DescribeLogStreamsRequest {
LogGroupName = "logGroup",
OrderBy = "LastEventTime",
Descending = true,
});
And setting up cloud watch group and stream as follows:
_client.CreateLogGroupAsync(new CreateLogGroupRequest { LogGroupName = "logGroup" });
_client.CreateLogStreamAsync(new CreateLogStreamRequest {
LogGroupName = "logGroup",
LogStreamName = "logStream"
});
Than retrieving cloud watch logs as follows:
var request = new GetLogEventsRequest
{
LogStreamName = "logStream",
LogGroupName = "logGroup",
StartTime = DateTime.UtcNow.AddDays(-1),
EndTime = DateTime.UtcNow,
Limit = 50,
StartFromHead = false
};
var response = await GetLogEventsAsync(123, 456, 50, "000/f", "000/b");
var logs = response.Events;
The logs
are received as always oldest-first, not the latest-first.
Please suggest any fixes.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
Shakeel,我想知道您是否尝试过延长方法订购方法?我能够通过使用它来使它起作用:
returnValue是type
list&lt; cloudwatchlogevent&gt;
and logeventsResponse是task> task&lt; getlogeventsponse&gt;
and coundwatchlogevent and coundwatchlogevent是一个简单的类我创建了一个简单的类I创建了:Shakeel, I wondered if you had tried the extension method OrderByDescending? I was able to get this to work by using that:
returnValue is type
List<CloudWatchLogEvent>
and logEventsResponse isTask<GetLogEventsResponse>
and CloudWatchLogEvent is a simple class I created: