Skip to main content

Get logs from AWS Cloudwatch.

Project description

Cloudwatch logs

Get logs from AWS CloudWatch.

A wokring AWS configuration is expcted.

I personally use aws-vault for that matter.

Why

There are tools like saw, but I am not quite comfortable with all of them. So I just wanted to try and do it myself.

Usage

Get help:

    aws_cloudwatch_logs -h
    aws_cloudwatch_logs get-stream -h
    aws_cloudwatch_logs follow-stream -h
    aws_cloudwatch_logs insights -h

Get the most recent log events of a stream

    # Get log events going 1 hour back in time, until now.
    aws_cloudwatch_logs get-stream --region <aws_region> --group <log_group> --stream <log_stream_prefix>  --start-time 1
    # Get log events going 1 minute back in time, until now.
    aws_cloudwatch_logs get-stream --group <log_group> --stream <log_stream_prefix>  --start-time 1 --time_unit minutes

This returns the most recent log events of the given stream.

The --limit option actually affects the total number if log events returned.

Follow the most recent log events of a stream

    # Get log events going 1 hour back in time, follow the log stream and listen for more.
    aws_cloudwatch_logs follow-stream --region <aws_region> --group <log_group> --stream <log_stream_prefix>  --start-time 1

This is mostly the same as the above. It returns the most recent logevents of the given stream, but stays "connected" and gives every new incoming log event as well. The loop is broken e.g. by a KeyboardInterrupt.

The --limit option reduces the number of log events retrieved by a single request. Requests will be repeated (the stream is followed) until the program stops.

Using Insights

    aws_cloudwatch_logs insights --region <aws_region> --group <log_group> --start_time 1 --limit 1000 --query 'fields @timestamp, @message | sort @timestamp desc | limit 20'

This command allows querying AWS CloudWatch logs using Insights.

Configuration

Ways to configure

When used as an executable or script the configuration happens using cli arguments.

The tool also considers environment variables.

This is the mapping:

cli option environemt variable default
-r, --region AWS_REGION eu-west-1
-g, --group LOG_GROUP None
-s, --stream LOG_STREAM None
--start_time START_TIME 3
--time_unit TIME_UNIT hours
--limit LIMIT 20
--query QUERY fields @timestamp, @message | sort @timestamp desc | limit 20

Options

The --start_time expects an integer. Additionally the option --time_unit, which defaults to hours, can be used.

--start_time defaults to 3.

Possible values for --time_unit are:

  • hours (default)
  • minutes

Also, there is a --limit option which limits the result per request.

--limit defaults to 20.

The given log stream name is evaluated using the option logStreamNamePrefix of the filter_log_events function of the boto3 logs client. I.e. it's not important to specifiy the complete and exact log stream name, but an exact prefix.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aws_cloudwatch_logs-0.1.0.tar.gz (7.5 kB view details)

Uploaded Source

File details

Details for the file aws_cloudwatch_logs-0.1.0.tar.gz.

File metadata

  • Download URL: aws_cloudwatch_logs-0.1.0.tar.gz
  • Upload date:
  • Size: 7.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.5

File hashes

Hashes for aws_cloudwatch_logs-0.1.0.tar.gz
Algorithm Hash digest
SHA256 830bd545027fe9003e2bb5dee4ed75d87a6046035bf3596a85429639ac930262
MD5 4555a4ecd7392bbd39c8e56c09aeb714
BLAKE2b-256 e4548b68c032d2081e486ff914bff2dabb25d09f3d62f8cd93335fa0fe06d9cb

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page