Tooling to manage the Retention Compliance for AWS CloudWatch logs
Project description
CloudWatch Logs Retention Manager is a configurable tool that can be used to validate or enforce CloudWatch log retention rules.
Unlike other tools in this space, the cwlrm provides flexibility through the use of configuration, this configuration can apply to a subset of log groups - useful when working in shared environments.
Usage
Install cwlrm through pip and create a config.yml file within your project.
➜ cwlrm --help usage: cwlrm [-h] [--version] [-u] [-c CONFIGFILE] [-s] [-sc] [-ic] [-v] [-vv] CloudWatch logs retention manager optional arguments: -h, --help show this help message and exit --version show program's version number and exit -u, --update update settings in AWS -c CONFIGFILE, --config CONFIGFILE location of config.yaml -s, --show_all show all log groups in filter -sc, --show_cost total cost per groups -ic, --show_individual_cost show storage cost for each log group in filter -v, --verbose set loglevel to INFO -vv, --very-verbose set loglevel to DEBUG
Once installed, all that is needed is a config.yml file containing the log group patterns and retention periods to set. The tool supports a Compliance mode, where the live AWS environment will be validated against the described config file.
When you are ready to apply the changes, run cwlrm -u to enforce Compliance as defined.
The format of the config.yml file is as follows:
A single root object names retentionPatterns
An array of child objects consisting of the following attributes:
name - mandatory - names a section of log groups to be processed
logPrefix - optional - the pattern of logs to apply the group to - default: all logs
retentionInDays - optional - the log retention period to set - default: Forever
override - optional - if set will require the exact retentionInDays values to be compliant, otherwise any log retention is considered compliant - default: false
showAlways - optional - when set, will show all log groups that match irrespective of their compliance - default: false
Optionally the logPrefix can be an array of patterns to be collected into the matching group.
Example:
retentionPatterns: - name: CodeBuild jobs logPrefix: /aws/codebuild/ retentionInDays: 14 override: true showAlways: true - name: AWS Glue Crawlers logPrefix: /aws-glue/crawlers retentionInDays: 14 - name: Specific application lambda logs logPrefix: - /aws/lambda/Application1 - /aws/lambda/Application2 - /aws/lambda/Application3 retentionInDays: 45 - name: Lambda logs logPrefix: /aws/lambda retentionInDays: 30 - name: API Gateway access logs logPrefix: /aws/api-gateway/ retentionInDays: 120 - name: API Gateway Execution Logs logPrefix: API-Gateway-Execution-Logs retentionInDays: 120 - name: All remaining log groups showAlways: true retentionInDays: 90
IMPORTANT Note: For each run a log group will only be processed by a single control - the first control to process the log group will be the active one, if subsequent patterns are to match that same log group it will be ignored.
Examples
Some example config files.
Simple retention pattern
retentionPatterns: - name: AWS Glue Crawlers logPrefix: /aws-glue/crawlers retentionInDays: 14 - name: CloudFront Lambda Function logs logPrefix: /aws/cloudfront/LambdaEdge retentionInDays: 30
This configuration will ensure that all glue-crawler and lambdaedge function logs have a retention set, when applied will set 15 and 30 days respectivly.
Specific compliance retention period
retentionPatterns: - name: CodeBuild jobs logPrefix: /aws/codebuild/ retentionInDays: 14 override: true
This configuration will enforce that all codebuild log groups have specifically a 14 day retention period - any other value will be considered “Non Compliant”
Logs that should be retained Forever
retentionPatterns: - name: Application audit logs logPrefix: /application/audit/ showAlways: true
If a log group contains some sort of audit required for long term archive, Compliance can be achieved by specifiying the logGroup pattern and omitting the retentionInDays parameter. In this scenario log groups without retention periods are considered Compliant, and are configured to be shown on each execution.
Show all remaining log groups
retentionPatterns: - name: API Gateway access logs logPrefix: /aws/api-gateway/ retentionInDays: 30 - name: Lambda API logs logPrefix: /aws/lambda/ retentionInDays: 30 - name: API Gateway Execution Logs logPrefix: API-Gateway-Execution-Logs retentionInDays: 30 - name: All remaining log groups showAlways: true retentionInDays: 90
A normal operation of cwlrm will only process the specified log groups (as selected by the logPrefix) - in some cases you may want to apply a default to the entire account, this can be done through the omission of the logPrefix attribute. Any log group matching the previous conditions will
Note
This project has been set up using PyScaffold 4.0.1. For details and usage information on PyScaffold see https://pyscaffold.org/.
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
Built Distribution
File details
Details for the file cloudwatch-log-retention-manager-0.1.4.tar.gz
.
File metadata
- Download URL: cloudwatch-log-retention-manager-0.1.4.tar.gz
- Upload date:
- Size: 20.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 403668541ea5a2fc2e5b94173e6675d60e7f8f7aa86b81f4c2e4c1b9a552691b |
|
MD5 | 680f096119aa695598b9c162436413db |
|
BLAKE2b-256 | 616a1cd05e1793171157c128c3c191d63f529bd263bc84973fd6a7d06a7c97a2 |
File details
Details for the file cloudwatch_log_retention_manager-0.1.4-py2.py3-none-any.whl
.
File metadata
- Download URL: cloudwatch_log_retention_manager-0.1.4-py2.py3-none-any.whl
- Upload date:
- Size: 10.0 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 66435cd0e87711bcad151e8c245553e0f7a476213c1d7787ba72fe9a8e93f1bd |
|
MD5 | 5b2a7b142aeabd72f3abefff2b7e6a7e |
|
BLAKE2b-256 | 7b45b0d7c13ad11112846e4345b7ac00ef7ab0cd3da0972d496be743d09f9829 |