################################################################################ # CoreAMI provisioning scripts ################################################################################ boot_core_ami Triggered by /etc/rc.local boot_core_ami is used to perform initial actions based on specified user-data. It determines whether or not to run puppet_init.sh(see below), pull down a payload (which is attempts to decompress), and/or run any commands which maybe useful for interacting with the payload. puppet_init.sh This is the puppet first run script. By default CoreAMIs are not configured to start puppet automatically. So, puppet_init.sh first attempts to contact the puppet server 5 times (waiting for user-data to register), Then if a catalog can be compiled puppet_init.sh first pulls the base yum repository then completes a catalog run. CloneAMI.sh Used to create a "frozen" AMI from a CoreAMI that has had a build deployed with all necessary packages and configurations (for autoscaling) ################################################################################ # Puppet server related functionality ################################################################################ Node_Terminus Upon a puppetd request to the puppet server, instead of looking to file-based puppet node configuration, Node_Terminus.py queries the AWS REST API for all instances and creates YAML to be used for catalog compilation NOTE: The following cron job should be used to clear out old puppet private keys (for nodes) to clean-up for new instances using old instance private DNS entries. Set to run every hour and remove keys over 1 day old. 1 * * * * find /var/lib/puppet/ssl/ca/signed/ -type f -mtime +1 -exec rm -f {}\; id_to_hostname.rb (A puppet function) used to determine the index of an EC2 Instance ID in a particular Auto Scale Group. The result is an FQDN of "domain prefix" + index + "domain suffix" which can be used to associate an Elastic IP. Example of use: $wwwfqdn = id_to_hostname("www-asg", "www", $ec2_instance_id, ".example.com") NOTE: On CentOS running Puppet 0.25.X This file should be placed here: /usr/lib/ruby/site_ruby/1.8/puppet/parser/functions/id_to_hostname.rb