Skip to content

jbraeuer/ec2-boot-init

 
 

Repository files navigation

What is it?

A script to help bootstrap generic EC2 instances into specific ones.

The basic idea is that you submit some user data in the form:

--- 
:facts: 
  foo: bar
:actions: 
- :url: http://your.net/ec2commands/
  :type: :getcommands
- :master: puppet.your.net
  :type: :puppet

This script when run from your init system will:

The puppet action isn't shipped but can be supplied by your on the URL to the getcommands action.

You should use this to do the basic bootstrap actions like get Puppet on your node, do the basic setup etc. From there you'd configure the machine using Puppet.

Actions:

Actions are written in ruby, here's a simple one that execute a shell command:

newaction("shell") do |cmd, ud, md, config|
    if cmd.include?(:command)
        system(cmd[:command])
    end
end

Facts:

Once run all the EC2 meta data and user data are cached locally and a file /etc/facts.txt gets written in a list of key=value pairs.

Ideal for importing in tools like Facter.

Status:

This is very early work-in-progress chunk of code.

About

Tool to help boot EC2 instances via user and meta data

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 100.0%