Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Question: LogMonitoring with addMaxIncomingLogsAlarm and a Pattern #579

Open
sndpl opened this issue Oct 8, 2024 · 2 comments
Open

Question: LogMonitoring with addMaxIncomingLogsAlarm and a Pattern #579

sndpl opened this issue Oct 8, 2024 · 2 comments

Comments

@sndpl
Copy link

sndpl commented Oct 8, 2024

Hi,

since 22 march it's possible to add an addMaxIncomingLogsAlarm to the LogMonitoring (#504). But I was wondering, if you set a pattern like:

.monitorLog({
  logGroupName: ".....",
  pattern: "ERROR",
  addMaxIncomingLogsAlarm: {
	  Critical: {
		  maxCount: 5,
		  period: Duration.minutes(5),
		  treatMissingDataOverride: TreatMissingData.NOT_BREACHING,
		  actionOverride: new SnsAlarmActionStrategy({
			  onAlarmTopic: criticalTopic,
			  onOkTopic: criticalTopic,
		  }),
	  },
  },
});

It shows the log lines which contain the pattern (very nice), but it also shows the incoming logs on which it creates the alarm:

image

But those incoming logs are not filtered with the given pattern? Also the alarm is not using the pattern.

I would expect that it creates an alarm that count's the log lines with the pattern and if there are more then 5 in a period of 5 min it goes into the alarm state. So is it a bug or do I just not understand where this addMaxIncomingLogsAlarm feature is for? because It now just creates a sample count alarm that goes in alarm state if the lambda is called more then 5 times in 5 min.

@maltelorbach
Copy link

Possibly not even directly related to the alarm feature, because the Incoming logs widget doesn't filter using the pattern at all.

In my case (without alarm), no log lines match the pattern, but the visualization simply shows all incoming logs.

facade.monitor_log(
    log_group_name=log_group.log_group_name,
    human_readable_name=name,
    pattern=f'"level":"{level.upper()}"',
    alarm_friendly_name=name.lower(),
    limit=limit,
)

image

@joeydebreuk
Copy link

👋

I created the initial feature request here, I can confirm it doesn't work for me either. The alarm raises for any log statement, regardless of the pattern.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants