Skip to content
forked from acquia/moonshot

Moonshot: Because releasing services shouldn't be a moonshot!

License

Notifications You must be signed in to change notification settings

codwazny/moonshot

This branch is 136 commits behind acquia/moonshot:master.

Repository files navigation

Moonshot Documentation StatusBuild StatusTest CoverageCode ClimateGem Version

Because releasing services shouldn't be a moonshot.

Overview

We also have pretty docs, lots more to find there.

Moonshot is a Ruby gem for provisioning environments in AWS using a CLI. The environments are centered around a single CloudFormation stack and supported by pluggable systems:

  • A DeploymentMechanism controls releasing code.
  • A BuildMechanism creates a release artifact.
  • A ArtifactRepository stores the release artifacts.

General Flow

Design Goals

These are core ideas to the creation of this project. Not all are met to the level we'd like (e.g. CloudFormation isn't much of a Choice currently), but we should aspire to meet them with each iteration.

  • Simplicity: It shouldn't take more than a few hours to understand what your release tooling does.
  • Choice: As much as possible, each component should be pluggable and omittable, so teams are free to use what works best for them.
  • Verbosity: The output of core Moonshot code should explain in detail what changes are being made, so knowledge is shared and not abstracted.

Existing limitations

  • Moonshot does not support detailed error logging from Cloudformation substacks.
  • Moonshot does not support a non-local cloudformation file.

Installation

Add this line to your application's Gemfile:

gem 'moonshot'

And then execute:

$ bundle install

Or install it yourself as:

$ gem install moonshot

After installation, there is still some work required. Follow the example documentation as described below to dig in!

Getting started

The Moonshot tool has been designed to be an extensible library for your specific use-case. Interested in how it can be used? See our example documentation. The example doc uses the files shown in the sample directory so you can figure out how to modify this for your own deployment strategy.

We also want to help you contribute and answer all your questions on how Moonshot is maintained.

Requirements

  • Ruby 2.1 or higher

Attributions

Thanks to Acquia Inc. for sponsoring the time to work on this tool. Thanks to Ted for the funky logo.

About

Moonshot: Because releasing services shouldn't be a moonshot!

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 72.0%
  • Shell 21.7%
  • Python 2.5%
  • Puppet 1.6%
  • HTML 1.2%
  • Java 0.8%
  • Other 0.2%