No commit activity in last 3 years
No release in over 3 years
The instance_accountant gem is designed to be used to account for hourly resource consumption, such as EC2 instances, using Subledger, the double-entry accounting API. It can account for both cost (amount owed to AWS) as well as price (amount owed to instance owner). If you run hourly-billed instances for yourself, or for others, and want real-time usage information for yourself, and for those paying you for the instance, then this gem is for you. :-) instance_accountant keeps state in an "hourfile" that contains the timestamp of the last hour accounted for. It is intended to be run in --daemon mode at startup. It makes no effort to account for instance time when it is not running, so it's important to run it immediately upon startup, and to make sure that it is always running.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

~> 0.7
~> 0.19
 Project Readme

Subledger instance accountant Ruby gem

Installation:

gem install instance_accountant

Gemfile:

gem 'instance_accountant'

The gem provides an executable that can be invoked two ways:

  1. you want to account for the hourly cost of instances:

    #!/bin/bash

    instance_accountant account
    --cost 0.1
    --cost_reference 'http://test.com/cost'
    --expense_acct subledger_account_id
    --payable_acct subledger_account_id
    --key_id subledger_key_id
    --secret subledger_secret
    --org_id subledger_org_id
    --book_id subledger_book_id
    --daemon 2>&1 >> instance_accountant.log

  2. you want to account for both the hourly cost and income:

    #!/bin/bash

    instance_accountant account
    --cost 0.1
    --expense_acct subledger_account_id
    --payable_acct subledger_account_id
    --price 0.2
    --receivable_acct subledger_account_id
    --income_acct subledger_account_id
    --key_id subledger_key_id
    --secret subledger_secret
    --org_id subledger_org_id
    --book_id subledger_book_id
    --daemon 2>&1 >> instance_accountant.log

Here's a complete set of options:

Options:
  f, [--filepath=FILEPATH]
                                               # Default: ~/.instance_accountant
  d, --description=DESCRIPTION
                                               # Default: instance usage for: %
      [--reference=REFERENCE]
  c, --cost=COST
      [--cost-description=COST_DESCRIPTION]
                                               # Default: instance cost for: %
      [--cost-reference=COST_REFERENCE]
  e, --expense-acct=EXPENSE_ACCT
  p, --payable-acct=PAYABLE_ACCT
  p, [--price=PRICE]
      [--price-description=PRICE_DESCRIPTION]
                                               # Default: instance price for %
      [--price-reference=PRICE_REFERENCE]
  i, [--income-acct=INCOME_ACCT]
  r, [--receivable-acct=RECEIVABLE_ACCT]
  k, --key-id=KEY_ID
  s, --secret=SECRET
  o, --org-id=ORG_ID
  b, --book-id=BOOK_ID
      [--daemon], [--no-daemon]

Note: %s in descriptions will be replaced by the ISO 8601 of the hour in UTC Note: instance_accountant captures errors and does its best to keep running