GitXplorerGitXplorer
d

awsbill2graphite

public
25 stars
7 forks
3 issues

Commits

List of commits on branch master.
Unverified
c88d24b3d7bea15df7574742d225799fa7b4bd70

make flake8 pass

committed 9 years ago
Unverified
fd4018746177ed1951290c3d1919e2dc8fc4a43f

Removed aspirational AWSBILL_TAGS docs. That's #4.

ddanslimmon committed 9 years ago
Unverified
64814020ac559c229ba1edc9bddfd87eda7c0477

Merge pull request #16 from rgardam/master

ddanslimmon committed 9 years ago
Unverified
2a8585f0f7c1987ed18e467b16d1905ca53b67b9

fixed bug with env variables

committed 9 years ago
Unverified
144d94f97bd4e1372e5358aeb4715ac64e6e3fc5

added region selection for s3 buckets

committed 9 years ago
Unverified
eb923f0d81a610a1bf032f95347cc3a7a22b3c1a

Added ElastiCache support

ddanslimmon committed 9 years ago

README

The README file for this repository.

awsbill2graphite

awsbill2graphite is a script that converts AWS hourly billing CSVs to Graphite metrics.

dashboard screenshot

If you want to hack on it, check out DEV.md.

So far, it does the following types of metrics:

  1. Per-region, per-EC2-instance-type cost by the hour
  2. EBS metrics, including storage costs, PIOPS costs, per-million-IOPS costs, and snapshot storage costs
  3. Per-region RDS costs, including storage, PIOPS, and instance-hours
  4. ElastiCache costs per-instance-type
  5. Total AWS cost by the hour

More are planned.

Prep

First of all, you'll need to have hourly billing reports enabled. You can do this through the AWS billing control panel.

awsbill2graphite has some dependencies. We don't have a pip package yet (but we have an issue for it. To install the dependencies, go into a virtualenv and run

pip install -r requirements.txt

The script will have to be run in that virtualenv.

In order to prevent Graphite from creating giant, mostly-zero data files, set the following in storage-schemas.conf:

[awsbill]
priority = 256
pattern = ^awsbill\.
retentions = 1h:3650d

Usage

First set the following environment variables:

  • AWSBILL_REPORT_PATH: The path where the report lives. If downloading from S3, this should be s3:// followed by the bucket name followed by the "Report path" as defined in the AWS billing control panel. If reading a local file, it should start with file:// and give the path to an hourly billing CSV file.
  • AWS_ACCESS_KEY_ID: The identifier for an AWS credentials pair that will enable access to the bucket with billing reports in it. If you're using a local file instead of downloading the report from S3, you can omit this.
  • AWS_SECRET_ACCESS_KEY: The secret access key that corresponds to AWS_ACCESS_KEY_ID. If you're using a local file instead of downloading the report from S3, you can omit this.
  • AWSBILL_GRAPHITE_HOST: The hostname of the Graphite server to which to write metrics. If instead you want to output metrics to stdout, set this environment variable to stdout. If the Graphite port is not the default of 2003, you may append it after a colon.
  • AWSBILL_METRIC_PREFIX: The prefix to use for metrics written to Graphite. If absent, metrics will begin with "awsbill.". If you set this, you should modify the [awsbill] stanza you added to Graphite's storage-schemas.conf accordingly.

Then run

awsbill2graphite.py

This will produce metrics named like so:

PREFIX.REGION.ec2-instance.t2-micro
PREFIX.REGION.ec2-instance.c4-2xlarge
PREFIX.REGION.ebs.snapshot
PREFIX.REGION.ebs.piops
PREFIX.REGION.rds.db-r3-xlarge

Each metric will have a data point every hour. This data point represents the total amount charged to your account for the hour previous to the data point's timestamp.

Making Graphite/Grafana dashboards with these metrics

Here is a JSON description of a basic per-region-summary Grafana dashboard: grafana_dashboard.json.

A few notes:

  • Snapshots are only billed once daily, so the snapshot metrics will be equal to 0 for most of their values. The value they do contain will be the cost for that entire day, not the hour.
  • At the end of a month, the billing report you get will be missing most of the final day's data. That's just how AWS hourly billing reports work. Eventually (4 or 5 days after the end of the month) they give you a final report for the month, with all the data. So in the interim, you'll have a big ugly dip in your graphs.