S3 Capture Storage

Sysdig stores two types of data in S3 buckets: Captures and Rapid Response logs. Via remote connection, Captures allows you to record detailed system trace data, and Rapid Response allows you to execute commands. In SaaS installations, by default, Sysdig stores Captures and Rapid Response logs in Sysdig’s Amazon Simple Storage Service (S3) location. In on-premises installations, by default, the data will be stored in the Cassandra database. Sysdig stores captures for 90 days. You may wish to explore alternative storage options, for reasons of greater privacy, or in order to store data for longer periods of time.

The following alternative storage options are available for SaaS:

On-Prem users should see (On-Prem) Configure Custom S3 Storage.

(SaaS) Configure Custom AWS S3 Storage

If you want to use your own AWS S3 bucket, you must append some code to the Identity Access Management (IAM) Policy you created in AWS for Sysdig integration.

AWS integration is only available through the Monitor UI. If you are on a Secure-only SaaS license, you will need to configure your integrate AWS with Sysdig via API commands. See (SaaS Sysdig Secure Only) Configure Custom S3 Endpoint

Prerequisites

  • Your AWS account must be integrated with Sysdig. Ensure there is a valid account visible in Settings > Outbound Integrations | AWS.

  • Have an AWS bucket set up. Have your bucket name ready.

Set Up Your AWS Bucket

  1. Log in to AWS, and add the following code snippet in your Identity and Access Management (IAM) page:

    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Action": [
                    "s3:Put*",
                    "s3:List*",
                    "s3:Delete*",
                    "s3:Get*"
                ],
                "Effect": "Allow",
                "Resource": [
                "arn:aws:s3:::BUCKET_NAME",
                "arn:aws:s3:::BUCKET_NAME/*"
                ]
            }
        ]
    }
    

    Replace BUCKET_NAME with the bucket name you chose.

  2. If you are using AWS Key Management Service (KMS) for AWS S3 encryption, ensure that necessary privileges are given to the Sysdig Account or Role to use the custom key.

    Use the Key users option to do so:

  3. Log in to Sysdig Monitor, and navigate to the S3 Capture Storage page via Settings or Integrations.

  4. Toggle to Enable custom S3 bucket and enter your AWS S3 bucket name.

    Ensure that you enter the exact name you’ve used earlier.

  5. Ignore the optional fields Principal and Trace files root folder.

  6. Ignore the optional code snippet generated on this page.

    Code snippet might result in an error.

  7. Enable SSE-C encryption if needed.

    The key must be AES-256 and Base64 encoded. When this option is enabled, all data is stored and read by using the provided key. Use the correct key to avoid loosing access to the data.

Upon setting or changing the SSE-C key, the old data will become unreadable. Sysdig does not provide tools for migrating the data.

To Test: Capture a Trace File in Sysdig Monitor UI

When configured successfully, you will have the option to select between Sysdig Monitor Storage or your own storage bucket when configuring a capture.

S3 Storage API Description

The endpoint for configuring S3 Storage is /api/sysdig/settings.

The endpoint takes the following parameters as part of the payload:

  • enabled: Boolean. Specifies if this S3 bucket enabled or not.
  • enabledSSE: Boolean. Specifies if Server Side Encryption should be enabled (default on for AWS).
  • enabledSSE_C: Boolean. Specifies if the user Provided Server-Side Encryption key should be used.
  • customerEncryptionKey: String. The Base64-encoded AES256 encryption key to be used. Applicable only if enabledSSE_C is used.
  • buckets
    • providerKeyId: Integer. The API provider key ID. Retrieved from the call to /api/providers.
    • name: String. A unique name to identify your S3 bucket.
    • description: String. A description about the S3 bucket.
    • region: String. A label that identifies where the S3 bucket is located.
    • endpoint: String. The endpoint label.
    • folder: String. The folder path. For example: “/”.
    • pathStyleAccess: Boolean. Specifies if the Path Style Access should be forced.
      • true: Force path style access.
      • false or null: Try to infer. If the endpoint contains an IP, use path style access. If the endpoint contains a DNS name, use virtual host style access.
    • awsKey: String: Obsolete; not used any more.

Not all parameters are required and required parameters depend on the use case. See below for specific use cases.

(SaaS Secure Only) Configure Custom S3 Endpoint

If your Sysdig license does not include Sysdig Monitor, you will not be able to integrate AWS through the UI. Instead, configure your AWS S3 storage bucket by executing two HTTP requests against the Sysdig API. This can be accomplished through either using an ID and KEY or AWS Role Delegation.

Use ID and Key

This is the recommended method for the GCP-hosted regions, such as US West and the Middle East. See SaaS Regions. For all other regions and on-prem, we recommend you Use AWS Role Delegation.

Prerequisites

  • Have an AWS S3 Storage bucket set up.

  • Have your AWS ID (Access Key ID) and key (Secret Access Key) ready.

Configure a Custom S3 Bucket

  1. Create a new customer provider key setting with POST endpoint: /api/providers

    curl $HOST \
        -k -X POST \
        -H "Content-Type: application/json" \
        -H "Authorization: Bearer ${TOKEN}" \
        -d "{ \"name\": \"aws\", \"credentials\": { \"id\": \"${ID}\", \"key\": \"${KEY}\" }}"
    

    Example result after running the first query:

    {
        "provider": {
            "id": <PROVIDER_ID>,
            "name": "aws",
            "credentials": {
                "id": "*****",
                "role": null
            },
            "tags": [],
            "status": {
                "status": "configured",
                "lastUpdate": 1683114364207,
                "percentage": 0,
                "lastProviderMessages": []
            },
            "alias": null,
            "accountId": null,
            "skipFetch": false,
            "regions": null
        }
    }
    

    Note the id from this response.

  2. Create a new storage configuration with POST endpoint: /api/sysdig/settings. Set providerKeyId to the database id generated by your previous POST command. BUCKET_NAME must match your bucket name:

    curl $HOST \
        -k -X POST \
        -H "Content-Type: application/json" \
        -H "Authorization: Bearer ${TOKEN}" \
        -d "{ \"enabled\": true, \"buckets\": [{ \"folder\":\"/\", \"name\": ${BUCKET_NAME}, \"providerKeyId\": ${PROVIDER_ID} }] }"
    

    Example result after running the second query:

    {
        "enabled": true,
        "enabledSSE": false,
        "buckets": [
            {
                "awsKey": null,
                "name": "<BUCKET_NAME>",
                "folder": "/",
                "description": null,
                "providerKeyId": <PROVIDER_ID>,
                "endpoint": null,
                "region": null
            }
        ]
    }
    

    Your custom S3 storage has now been configured for Secure. To test, check you have the option to select between Sysdig Secure Storage or your own storage bucket when configuring a capture.

Use AWS Role Delegation

This is the recommended method for most regions. For GCP-hosted regions, such as US West and the Middle East, we recommend you Use ID and Key.

Prerequisites

Configure a custom S3 bucket

  1. Create a policy with these permissions:

    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Action": [
                    "s3:Put*",
                    "s3:List*",
                    "s3:Delete*",
                    "s3:Get*"
                ],
                "Effect": "Allow",
                "Resource": [
                    "arn:aws:s3:::BUCKET_NAME",
                    "arn:aws:s3:::BUCKET_NAME/*"
                ]
            }
        ]
    }
    
    • Replace BUCKET_NAME with the name of your S3 bucket.

    • Link the role with the policy above.

  2. Create a new customer provider key setting with POST endpoint: /api/providers.

    curl $HOST \
        -k -X POST \
        -H "Content-Type: application/json" \
        -H "Authorization: Bearer ${TOKEN}" \
        -d "{ \"name\": \"aws\", \"role\": \"${ARN}"\"}"
    
    • Replace ARN with the Amazon Resource Name (ARN) of your AWS role.

    • Here’s a sample result after running the first query. <ACCOUNT_ID> is the AWS Account ID, <ROLE_NAME> is the name of the role, and <PROVIDER_ID> is the provider ID in Sysdig.

    {
        "provider": {
            "id": <PROVIDER_ID>,
            "name": "aws",
            "credentials": {
                "id": "role_delegation",
                "role": "arn:aws:iam::<ACCOUNT_ID>:role/<ROLE_NAME>"
            },
            "tags": [],
            "status": {
                "status": "",
                "lastUpdate": 1683823773381,
                "percentage": 0,
                "lastProviderMessages": []
            },
            "alias": null,
            "accountId": "<ACCOUNT_ID>",
            "skipFetch": false,
            "regions": null
        }
    

    Note the id from this response.

  3. Create a new storage configuration with POST endpoint: /api/sysdig/settings

    curl $HOST \
        -k -X POST \
        -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -d "{ \"enabled\": true, \"buckets\": [{ \"folder\":\"/\", \"name\": ${BUCKET_NAME}, \"providerKeyId\": ${PROVIDER_ID} }] }"
    
    • The providerKeyId parameter should be set to the database id that was generated from the previous POST command.

    • BUCKET_NAME must match your bucket name.

    Here’s a sample result after running the second query:

    {
        "enabled": true,
        "enabledSSE": false,
        "buckets": [
            {
                "awsKey": null,
                "name": "<BUCKET_NAME>",
                "folder": "/",
                "description": null,
                "providerKeyId": <PROVIDER_ID>,
                "endpoint": null,
                "region": "us-east-1"
            }
        ]
    }
    

    Your custom S3 storage has now been configured for Secure. To test, check you have the option to select between Sysdig Secure Storage or your own storage bucket when configuring a capture.

(SaaS) Configure Custom S3 Storage

You can set up a custom AWS-S3-compatible storage, such as GCP, Minio, and IBM Cloud Object Storage, for storing Captures and Rapid Response logs. This is an API-only functionality and currently no UI support is available.

If Google Cloud Storage is used as the S3-compatible storage, you will not be able to bulk delete captures due to compatibility issues with Google’s S3 API implementation. You can delete captures one by one or delete them directly from the Google console.

The example below is for GCP, but is easily adaptable to Minio and IBM Cloud Object Storage.

To configure a Custom S3 bucket via the Sysdig API, follow these steps:

  1. Get hold of an id and key. In GCP, for example, this is found in the Interoperability tab of the GCP Storage settings.

  2. Create a new customer provider key setting with POST endpoint: /api/providers, using the parameters you’ve generated in step 1.

    curl $HOST \
        -k -X POST \
        -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -d "{ \"name\": \"aws\", \"skipFetch\": true, \"credentials\": { \"id\": \"${ID}\", \"key\": \"${KEY}\" }}"
    
  3. Create a new storage configuration with POST endpoint: /api/sysdig/settings, using the database id you generated in step 2 for the providerKeyId parameter.

    curl $HOST \
        -k -X POST \
        -H "Content-Type: application/json" \
        -H "Authorization: Bearer $TOKEN" \
        -d "{ \"enabled\": true, \"buckets\": [{ \"folder\":\"/\", \"name\": $BUCKET_NAME, \"providerKeyId\": $PROVIDER_KEY, \"endpoint\": \"$ENDPOINT\" }] }"
    
  • In the case of GCP, the endpoint parameter should be set to https://storage.googleapis.com

  • When including a folder name, omit any prefix slashes. For example, “test-folder” is acceptable, but not "/test-folder".

(On-Prem) Configure Custom S3 Storage

You can set up a custom Amazon-S3-compatible storage, such as Minio or IBM Cloud Object Storage, for storing Captures and Rapid Response logs in a Sysdig on-premises deployment. The storage location can be used for both Sysdig Monitor and Sysdig Secure. This is an API-only functionality and currently, no UI support is available.

In the steps below, you will configure values.yaml in accordance with your Sysdig installation.

Prerequisites

  • Your on-premises installation is Installer-based. If you have installed Sysdig Platform manually and you want to configure custom S3 buckets to store your files, contact your Sysdig representative.

  • Ensure that AWS-client compatible credentials used for authentication are present in the environment.

  • Ensure that the list, get, and put operations are functional on the S3 bucket that you wish to use. Confirm this by using the S3 native tools, for example, as described in AWS Command Line Interface (CLI) for IBM Cloud.

Configure Installer

Configure the following parameters in the values.yaml file so that collectors, workers, and the API server are aware of the custom endpoint configuration.

  • sysdig.s3.enabled

    Required: true
    Description: Specifies if storing Sysdig Captures in S3 or S3-compatible storage is enabled or not.
    Options:true|false
    Default:false
    

    For example:

    sysdig:
      s3:
        enabled: true
    
  • sysdig.s3.endpoint

    Required: true
    Description: The S3 or S3-compatible endpoint for the bucket. This option is ignored if sysdig.s3.enabled is not configured.
    

    For example:

    sysdig:
      s3:
        endpoint: <your S3-Compatible custom bucket>
    
  • sysdig.s3.capturesFolder

     Required: false
     Description: Name of the folder in S3 bucket to be used for storing captures, this option is ignored if sysdig.s3.enabled is not configured.
    

    For example:

    sysdig:
      s3:
        capturesFolder: my_captures_folder
    

    The path to the capture folder in the S3 bucket will be ​{​​customerId​​}/{​my_captures_folder​​}​​. For on-prem deployments, the ​customerID​ is ​1​​. If your capture folder is named ​finance​, the path to the folder in the S3 bucket will be 1/finance​​.

  • sysdig.s3.bucketName

    Required: true
    Description: The name of the S3 or S3-compatible bucket to be used for captures. This option is ignored if sysdig.s3.enabled is not configured
    

    For example:

    sysdig:
      s3:
        bucketName: <Name of the S3-compatible bucket to be used for captures>
    
  • sysdig.accessKey

    Required: true
    Description: The AWS or AWS-compatible access key to be used by Sysdig components to write captures in the S3 bucket.
    

    For example:

    sysdig:
      accessKey: <AWS-compatible access key>
    
  • sysdig.secretKey

    Required: true
    Description: The AWS or AWS-compatible secret key to be used by Sysdig components to write captures in the s3 bucket.
    

    For example:

    sysdig:
      secretKey: <AWS-compatible secret key>
    

The following AWS CLI command uploads a Sysdig Capture file to a Minio bucket:

aws --profile minio --endpoint http://10.101.140.1:9000 s3 cp <Sysdig Capture filename> s3://test/

In this case, the endpoint is http://10.101.140.1:9000/ and the name of the bucket is test.

When you finish the S3 configuration, continue with the instructions for on-premises installation by using the Installer.