GitXplorerGitXplorer
d

awsbill2graphite

public
25 stars
7 forks
3 issues

Commits

List of commits on branch master.
Unverified
98f60d7c8cf8784f5ad46322310994b86403ebde

Fix for breaking change to CSV format introduced in Sep 2016

committed 8 years ago
Unverified
bc57901e76d919ef2c73628d7e8142eac2d66bf4

Added number of metrics to logging output

ddanslimmon committed 9 years ago
Unverified
b40750f789dc164b5aca6cc039dd5e82aa9b8ae5

Added script to fetch and print all billing CSVs in the bucket.

ddanslimmon committed 9 years ago
Unverified
5be1c556606b74713646d535119e7efe20338e50

Merge pull request #18 from rgardam/master

ddanslimmon committed 9 years ago
Unverified
931c1091db3ebb3dd93bbb0ddbb56382d705bed8

fixed bug for when the storage is unknown

committed 9 years ago
Unverified
05a8c987c7cdb9b25baebfef649ab1ad2a5bed38

Merge pull request #17 from rgardam/master

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.