Log Archiving

Overview

By setting up archive rules, you can configure Lumigo to forward some or all of your logs to a specified S3 bucket. Archiving allows you to store logs indefinitely, comply with regulatory requirements, and query archived logs using Athena.

How does it work?

  1. When a new log arrives in Lumigo, it is evaluated against all your archive rules.
  2. If a log matches an archive rule, it is sent to an S3 bucket according to the rule's configuration

📘

Important Note

If a log matches multiple archive rules, it will be stored in multiple S3 buckets.

Configure Archive Rule

1. Create an S3 bucket

Login to your AWS console and create an S3 bucket to store your archived logs.

2. Set permissions

Create a new policy using the following JSON:

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Effect": "Allow",
            "Principal": {
              # replace YOUR_LUMIGO_ROLE_ARN with your Lumigo role ARN
              "AWS": "<<YOUR_LUMIGO_ROLE_ARN>>"
            },
            "Action": "s3:PutObject",
            "Resource": [
              # replace YOUR_S3_BUCKET_NAME with your archives bucket names
              "arn:aws:s3:::<YOUR_S3_BUCKET_NAME>/*"
            ]
        }
    ]
}

📘

Note

  • The PutObject permission is used for uploading logs to your S3 buckets
  • Ensure that the resource value ends with /* to apply the put permission to objects within the bucket

3. Route logs to archive buckets using archive rules

This feature will soon be supported directly via the Lumigo platform. Until then, you can contact support via Intercom to create your archive rules.

How to use archived logs?

Each of the files in the bucket contain logs aggregated according to their timestamp.

  1. Every line in the logs file is a JSON that represents a single log, and contains the details below:

{"timestamp": "2024-05-22T09:15:27.337000", "request_id": "REQUEST_ID", "resource_id": "resource_id", "message": "the actual log"}

  1. The log files are zipped
  2. To query your logs, you can use Athena. Make sure to use Table type Apache Hive and File format JSON.