The SAU Exporter is a Python-based application designed to collect and expose AWS EC2 and EBS volume metrics for monitoring and observability. It utilizes the Prometheus client library to provide an HTTP endpoint for scraping metrics.
Project description
SAU Exporter
Overview
The SAU Exporter is a Python-based application designed to collect and expose AWS EC2 and EBS volume metrics for monitoring and observability. It utilizes the Prometheus client library to provide an HTTP endpoint for scraping metrics.
Features
- EC2 Metrics: Collects information about stopped EC2 instances in different AWS regions.
- EBS Volume Metrics: Retrieves data on unattached/errored EBS volumes, including volume state, type, size, and region.
- Prometheus Integration: Exposes metrics in the Prometheus format, making it compatible with Prometheus monitoring systems.
Getting Started
Installing via pip
Offers support for python>=3.8
pip install sau
Using pip package after installation
python3 -m sau -c /path/to/config.yaml
Installing using docker
The docker repository is available at link. You will need the following:
- config file: see section
- AWS Credentials: It would be easier to put the creds in a env file and reference the file when running container. Example
.env
file can be seen below:
AWS_ACCESS_KEY_ID=129QJDNC2OQD09N
AWS_SECRET_ACCESS_KEY=9KXXXXXXXXX
AWS_REGION=eu-central-1
To run the container, use the example command below:
docker run -ti --env-file .env -v /path/to/config.yaml:/sau/config.yaml ugwuanyi/sau:latest -c /sau/config.yaml
Prerequisites:
- Python 3.8+ installed on your system.
- Ensure the required Python libraries are installed by running the following command.
pip install -r requirements.txt
Configuration:
Create a YAML configuration file with the necessary settings.
Configuration Options
- Regions: Specify the AWS regions for which you want to collect metrics.
- Exporter Port: Define the port on which the exporter will expose metrics (default: 9000).
- Logging Configuration: Customize logging settings, such as log file directory and retention. See example below.
# list of regions to scrape: REQUIRED
regions:
- eu-central-1
- eu-west-1
# exporter port. Defaults to 9000
exporter_port: 9000
# Logging configuration
logging:
# Number of log files to retain after log rotation
retention: 7
# log directory. defaults to current working directory
directory: "."
# log level (debug, info, warn, error). Defaults to info
level: info
Running the Exporter:
Execute the exporter by providing the path to the configuration file:
python3 sau_exporter.py -c /path/to/your/config.yaml
Metrics Endpoint:
Once the exporter is running, metrics can be accessed at http://localhost:<exporter_port>/
.
Customization
Feel free to extend or customize the exporter to meet your specific requirements. You can modify the provided code or add additional collectors to gather more AWS resource metrics.
License
This project is licensed under the MIT License. Feel free to use, modify, and distribute it according to the terms of the license.
Author
Created by Emeka Ugwuanyi. For questions or feedback, please contact me.
Happy monitoring!
Project details
Release history Release notifications | RSS feed
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 sau-test-0.0.0.tar.gz
.
File metadata
- Download URL: sau-test-0.0.0.tar.gz
- Upload date:
- Size: 9.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bda3edc681a6abe176b8156a30f8897f16e31dc222778fb09fbf237c5dee1325 |
|
MD5 | a0ba53a553273c417385a19f929b5108 |
|
BLAKE2b-256 | a13ac5c29f3ac31a3ee020d1199a75ae66e485e87665f1ec6c33db511346e229 |
File details
Details for the file sau_test-0.0.0-py3-none-any.whl
.
File metadata
- Download URL: sau_test-0.0.0-py3-none-any.whl
- Upload date:
- Size: 8.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3372e122945d0f13ecef46883cd95990affd3f56f19ec8c32afed9decaddd59d |
|
MD5 | a378c06b97c52c9a4be7993b39a8a125 |
|
BLAKE2b-256 | 0083eacebec7416e509c50a627653df9285ea76adfb897560d807baebdae7581 |