AWS CloudWatchLogs 不使用DescribeLogStreamsRequest 按降序返回日志

发布于 2025-01-18 02:25:55 字数 1538 浏览 1 评论 0原文

我正在使用 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;

一如既往地接收 日志 最旧的优先,而不是最新的优先

请提出任何修复建议。

参考: https://docs.aws.amazon.com/ sdkfornet/latest/apidocs/items/TCloudWatchLogsDescribeLogStreamsRequestNET45.html

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.

Ref: https://docs.aws.amazon.com/sdkfornet/latest/apidocs/items/TCloudWatchLogsDescribeLogStreamsRequestNET45.html

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

有深☉意 2025-01-25 02:25:55

Shakeel,我想知道您是否尝试过延长方法订购方法?我能够通过使用它来使它起作用:

returnValue.AddRange(logEventsResponse.Events.OrderByDescending(y => y.Timestamp).Select(x => new CloudWatchLogEvent { Message = x.Message, Timestamp = x.Timestamp.AddHours(-5), StreamName = stream.LogStreamName }));

returnValue是type list&lt; cloudwatchlogevent&gt; and logeventsResponse是task> task&lt; getlogeventsponse&gt; and coundwatchlogevent and coundwatchlogevent是一个简单的类我创建了一个简单的类I创建了:

public class CloudWatchLogEvent
{
    public string Message { get; set; }
    public DateTime Timestamp { get; set; }
    public string StreamName { get; set; }
}

Shakeel, I wondered if you had tried the extension method OrderByDescending? I was able to get this to work by using that:

returnValue.AddRange(logEventsResponse.Events.OrderByDescending(y => y.Timestamp).Select(x => new CloudWatchLogEvent { Message = x.Message, Timestamp = x.Timestamp.AddHours(-5), StreamName = stream.LogStreamName }));

returnValue is type List<CloudWatchLogEvent> and logEventsResponse is Task<GetLogEventsResponse> and CloudWatchLogEvent is a simple class I created:

public class CloudWatchLogEvent
{
    public string Message { get; set; }
    public DateTime Timestamp { get; set; }
    public string StreamName { get; set; }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文