fairchild-poolparty 1.1.3
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +35 -0
- data/License.txt +20 -0
- data/PostInstall.txt +19 -0
- data/README.txt +77 -0
- data/Rakefile +45 -0
- data/VERSION.yml +4 -0
- data/bin/cloud +32 -0
- data/bin/cloud-bootstrap +21 -0
- data/bin/cloud-configure +28 -0
- data/bin/cloud-console +12 -0
- data/bin/cloud-contract +17 -0
- data/bin/cloud-expand +19 -0
- data/bin/cloud-handle-load +27 -0
- data/bin/cloud-list +23 -0
- data/bin/cloud-osxcopy +17 -0
- data/bin/cloud-provision +30 -0
- data/bin/cloud-rsync +28 -0
- data/bin/cloud-run +18 -0
- data/bin/cloud-setup-dev +25 -0
- data/bin/cloud-show +27 -0
- data/bin/cloud-spec +41 -0
- data/bin/cloud-ssh +23 -0
- data/bin/cloud-start +28 -0
- data/bin/cloud-stats +17 -0
- data/bin/cloud-terminate +20 -0
- data/bin/ec2-list-active +24 -0
- data/bin/messenger-get-current-nodes +14 -0
- data/bin/pool +31 -0
- data/bin/pool-describe +8 -0
- data/bin/pool-generate +18 -0
- data/bin/pool-init +28 -0
- data/bin/pool-list +30 -0
- data/bin/pool-start +26 -0
- data/bin/server-become-master +24 -0
- data/bin/server-build-messenger +28 -0
- data/bin/server-butterfly +25 -0
- data/bin/server-clean-cert-for +15 -0
- data/bin/server-cloud-elections +26 -0
- data/bin/server-ensure-provisioning +38 -0
- data/bin/server-fire-cmd +14 -0
- data/bin/server-get-load +15 -0
- data/bin/server-list-active +26 -0
- data/bin/server-list-instances +15 -0
- data/bin/server-manage-election +67 -0
- data/bin/server-monitor.ru +25 -0
- data/bin/server-provision +32 -0
- data/bin/server-query-agent +15 -0
- data/bin/server-rerun +23 -0
- data/bin/server-send-command +18 -0
- data/bin/server-show-stats +17 -0
- data/bin/server-start-agent +15 -0
- data/bin/server-start-client +29 -0
- data/bin/server-start-master +26 -0
- data/bin/server-start-node +32 -0
- data/bin/server-stop-client +3 -0
- data/bin/server-stop-master +3 -0
- data/bin/server-stop-node +3 -0
- data/bin/server-update-hosts +49 -0
- data/bin/server-write-new-nodes +26 -0
- data/config/jeweler.rb +43 -0
- data/config/requirements.rb +7 -0
- data/examples/basic.rb +23 -0
- data/examples/deploy.rb +5 -0
- data/examples/fairchild.rb +32 -0
- data/examples/fairchild_chef.rb +19 -0
- data/examples/paparazzi.conf.erb +21 -0
- data/examples/plugin_without_plugin_directory.rb +12 -0
- data/examples/poolparty.rb +12 -0
- data/generators/poolspec/USAGE +5 -0
- data/generators/poolspec/poolspec_generator.rb +58 -0
- data/generators/poolspec/templates/pool_spec_template.erb +9 -0
- data/lib/erlang/messenger/Emakefile +1 -0
- data/lib/erlang/messenger/Makefile +15 -0
- data/lib/erlang/messenger/README +5 -0
- data/lib/erlang/messenger/Rakefile +72 -0
- data/lib/erlang/messenger/control +11 -0
- data/lib/erlang/messenger/ebin/client.app +19 -0
- data/lib/erlang/messenger/ebin/master.app +19 -0
- data/lib/erlang/messenger/ebin/node.app +19 -0
- data/lib/erlang/messenger/ebin/packager.app +19 -0
- data/lib/erlang/messenger/ebin/pm_client_rel-0.1.rel +1 -0
- data/lib/erlang/messenger/ebin/pm_master_rel-0.1.rel +1 -0
- data/lib/erlang/messenger/ebin/pm_node_rel-0.1.rel +1 -0
- data/lib/erlang/messenger/include/defines.hrl +27 -0
- data/lib/erlang/messenger/lib/eunit/AUTHORS +2 -0
- data/lib/erlang/messenger/lib/eunit/CHANGELOG +14 -0
- data/lib/erlang/messenger/lib/eunit/COPYING +504 -0
- data/lib/erlang/messenger/lib/eunit/Makefile +28 -0
- data/lib/erlang/messenger/lib/eunit/NOTES +276 -0
- data/lib/erlang/messenger/lib/eunit/README +3 -0
- data/lib/erlang/messenger/lib/eunit/doc/edoc-info +3 -0
- data/lib/erlang/messenger/lib/eunit/doc/erlang.png +0 -0
- data/lib/erlang/messenger/lib/eunit/doc/eunit.html +172 -0
- data/lib/erlang/messenger/lib/eunit/doc/index.html +17 -0
- data/lib/erlang/messenger/lib/eunit/doc/modules-frame.html +12 -0
- data/lib/erlang/messenger/lib/eunit/doc/overview-summary.html +984 -0
- data/lib/erlang/messenger/lib/eunit/doc/overview.edoc +980 -0
- data/lib/erlang/messenger/lib/eunit/doc/packages-frame.html +11 -0
- data/lib/erlang/messenger/lib/eunit/doc/stylesheet.css +55 -0
- data/lib/erlang/messenger/lib/eunit/ebin/autoload.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/code_monitor.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit.app +21 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit.appup +1 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_autoexport.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_data.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_lib.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_proc.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_serial.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_server.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_striptests.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_test.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_tests.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_tty.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/file_monitor.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/examples/eunit_examples.erl +339 -0
- data/lib/erlang/messenger/lib/eunit/examples/fib.erl +19 -0
- data/lib/erlang/messenger/lib/eunit/examples/tests.txt +1 -0
- data/lib/erlang/messenger/lib/eunit/include/eunit.hrl +313 -0
- data/lib/erlang/messenger/lib/eunit/src/Makefile +46 -0
- data/lib/erlang/messenger/lib/eunit/src/autoload.erl +388 -0
- data/lib/erlang/messenger/lib/eunit/src/code_monitor.erl +243 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit.app.src +21 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit.appup.src +1 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit.erl +196 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_autoexport.erl +102 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_data.erl +798 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_internal.hrl +48 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_lib.erl +682 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_proc.erl +552 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_serial.erl +157 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_server.erl +340 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_striptests.erl +64 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_test.erl +334 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_tests.erl +45 -0
- data/lib/erlang/messenger/lib/eunit/src/eunit_tty.erl +272 -0
- data/lib/erlang/messenger/lib/eunit/src/file_monitor.erl +409 -0
- data/lib/erlang/messenger/lib/eunit/sys.config +9 -0
- data/lib/erlang/messenger/lib/eunit/vsn.mk +1 -0
- data/lib/erlang/messenger/pm_client_rel-0.1.boot +0 -0
- data/lib/erlang/messenger/pm_client_rel-0.1.script +238 -0
- data/lib/erlang/messenger/pm_master_rel-0.1.boot +0 -0
- data/lib/erlang/messenger/pm_master_rel-0.1.script +239 -0
- data/lib/erlang/messenger/pm_node_rel-0.1.boot +0 -0
- data/lib/erlang/messenger/pm_node_rel-0.1.script +237 -0
- data/lib/erlang/messenger/src/client_app.erl +39 -0
- data/lib/erlang/messenger/src/client_server.erl +60 -0
- data/lib/erlang/messenger/src/master_app.erl +39 -0
- data/lib/erlang/messenger/src/node_app.erl +39 -0
- data/lib/erlang/messenger/src/pm_client.erl +49 -0
- data/lib/erlang/messenger/src/pm_client_supervisor.erl +38 -0
- data/lib/erlang/messenger/src/pm_cluster.erl +61 -0
- data/lib/erlang/messenger/src/pm_event_manager.erl +27 -0
- data/lib/erlang/messenger/src/pm_master.erl +215 -0
- data/lib/erlang/messenger/src/pm_master_event_handler.erl +72 -0
- data/lib/erlang/messenger/src/pm_master_supervisor.erl +39 -0
- data/lib/erlang/messenger/src/pm_node.erl +200 -0
- data/lib/erlang/messenger/src/pm_node_supervisor.erl +38 -0
- data/lib/erlang/messenger/src/pm_packager.erl +76 -0
- data/lib/erlang/messenger/src/pm_spawner.erl +213 -0
- data/lib/erlang/messenger/src/pm_strings.erl +11 -0
- data/lib/erlang/messenger/src/utils.erl +72 -0
- data/lib/erlang/messenger/useful_snippets +17 -0
- data/lib/poolparty/aska/aska.rb +152 -0
- data/lib/poolparty/base_packages/bind.rb +11 -0
- data/lib/poolparty/base_packages/haproxy.rb +46 -0
- data/lib/poolparty/base_packages/heartbeat.rb +58 -0
- data/lib/poolparty/base_packages/poolparty.rb +14 -0
- data/lib/poolparty/base_packages/ruby.rb +42 -0
- data/lib/poolparty/base_packages/runit.rb +21 -0
- data/lib/poolparty/capistrano/cloud_tasks.rb +10 -0
- data/lib/poolparty/capistrano.rb +54 -0
- data/lib/poolparty/config/postlaunchmessage.txt +5 -0
- data/lib/poolparty/core/array.rb +36 -0
- data/lib/poolparty/core/class.rb +26 -0
- data/lib/poolparty/core/exception.rb +10 -0
- data/lib/poolparty/core/float.rb +13 -0
- data/lib/poolparty/core/hash.rb +71 -0
- data/lib/poolparty/core/kernel.rb +66 -0
- data/lib/poolparty/core/metaid.rb +15 -0
- data/lib/poolparty/core/module.rb +40 -0
- data/lib/poolparty/core/my_open_struct.rb +18 -0
- data/lib/poolparty/core/object.rb +93 -0
- data/lib/poolparty/core/ordered_hash.rb +99 -0
- data/lib/poolparty/core/proc.rb +7 -0
- data/lib/poolparty/core/string.rb +140 -0
- data/lib/poolparty/core/symbol.rb +17 -0
- data/lib/poolparty/core/time.rb +56 -0
- data/lib/poolparty/dependencies.rb +49 -0
- data/lib/poolparty/dependency_resolver/chef_resolver.rb +221 -0
- data/lib/poolparty/dependency_resolver/dependency_resolver.rb +42 -0
- data/lib/poolparty/dependency_resolver/dependency_resolver_cloud_extensions.rb +28 -0
- data/lib/poolparty/dependency_resolver/puppet.rb +75 -0
- data/lib/poolparty/dependency_resolver/puppet_resolver.rb +173 -0
- data/lib/poolparty/exceptions/CloudNotFoundException.rb +7 -0
- data/lib/poolparty/exceptions/LoadRulesException.rb +7 -0
- data/lib/poolparty/exceptions/MasterException.rb +10 -0
- data/lib/poolparty/exceptions/ProvisionerException.rb +5 -0
- data/lib/poolparty/exceptions/RemoteException.rb +12 -0
- data/lib/poolparty/exceptions/ResourceException.rb +7 -0
- data/lib/poolparty/exceptions/RuntimeException.rb +7 -0
- data/lib/poolparty/exceptions/SpecException.rb +7 -0
- data/lib/poolparty/exceptions/TemplateNotFound.rb +7 -0
- data/lib/poolparty/exceptions/UnacceptableCommand.rb +5 -0
- data/lib/poolparty/exceptions/dependency_resolver_exception.rb +5 -0
- data/lib/poolparty/exceptions/package_exception.rb +7 -0
- data/lib/poolparty/extra/deployments.rb +31 -0
- data/lib/poolparty/helpers/binary.rb +67 -0
- data/lib/poolparty/helpers/console.rb +48 -0
- data/lib/poolparty/helpers/display.rb +30 -0
- data/lib/poolparty/helpers/hash_printer.rb +44 -0
- data/lib/poolparty/helpers/loading.rb +4 -0
- data/lib/poolparty/helpers/nice_printer.rb +36 -0
- data/lib/poolparty/helpers/optioner.rb +149 -0
- data/lib/poolparty/helpers/ruberl.rb +33 -0
- data/lib/poolparty/lite.rb +20 -0
- data/lib/poolparty/modules/cloud_dsl.rb +20 -0
- data/lib/poolparty/modules/cloud_resourcer.rb +122 -0
- data/lib/poolparty/modules/daemonizable.rb +141 -0
- data/lib/poolparty/modules/definable_resource.rb +57 -0
- data/lib/poolparty/modules/file_writer.rb +95 -0
- data/lib/poolparty/modules/output.rb +13 -0
- data/lib/poolparty/modules/pretty_printer.rb +40 -0
- data/lib/poolparty/modules/resourcing_dsl.rb +74 -0
- data/lib/poolparty/modules/s3_string.rb +32 -0
- data/lib/poolparty/modules/safe_instance.rb +31 -0
- data/lib/poolparty/modules/thread_pool.rb +106 -0
- data/lib/poolparty/monitors/base_monitor.rb +81 -0
- data/lib/poolparty/monitors/monitor_rack.rb +132 -0
- data/lib/poolparty/monitors/monitors/load_monitor.rb +15 -0
- data/lib/poolparty/monitors/monitors/memory_monitor.rb +50 -0
- data/lib/poolparty/monitors/monitors/server_monitor.rb +7 -0
- data/lib/poolparty/monitors/monitors/web_monitor.rb +18 -0
- data/lib/poolparty/monitors/neighborhood_monitor.rb +25 -0
- data/lib/poolparty/monitors/stats_monitor.rb +182 -0
- data/lib/poolparty/monitors.rb +6 -0
- data/lib/poolparty/net/init.rb +11 -0
- data/lib/poolparty/net/messenger.rb +55 -0
- data/lib/poolparty/net/remote_bases.rb +21 -0
- data/lib/poolparty/net/remote_instance.rb +109 -0
- data/lib/poolparty/net/remoter/cloud_control.rb +251 -0
- data/lib/poolparty/net/remoter/connections.rb +180 -0
- data/lib/poolparty/net/remoter/interactive.rb +121 -0
- data/lib/poolparty/net/remoter/lists.rb +12 -0
- data/lib/poolparty/net/remoter_base.rb +97 -0
- data/lib/poolparty/net/remoter_bases/ec2/ec2.rb +235 -0
- data/lib/poolparty/net/remoter_bases/ec2/ec2_remote_instance.rb +53 -0
- data/lib/poolparty/net/remoter_bases/ec2/ec2_response_object.rb +64 -0
- data/lib/poolparty/plugins/chef.rb +168 -0
- data/lib/poolparty/plugins/deploydirectory.rb +47 -0
- data/lib/poolparty/plugins/git.rb +66 -0
- data/lib/poolparty/plugins/line_in_file.rb +13 -0
- data/lib/poolparty/plugins/rsyncmirror.rb +28 -0
- data/lib/poolparty/plugins/runit.rb +96 -0
- data/lib/poolparty/plugins/svn.rb +48 -0
- data/lib/poolparty/poolparty/cloud.rb +216 -0
- data/lib/poolparty/poolparty/custom_resource.rb +45 -0
- data/lib/poolparty/poolparty/default.rb +167 -0
- data/lib/poolparty/poolparty/key.rb +75 -0
- data/lib/poolparty/poolparty/loggable.rb +28 -0
- data/lib/poolparty/poolparty/neighborhoods.rb +69 -0
- data/lib/poolparty/poolparty/plugin.rb +69 -0
- data/lib/poolparty/poolparty/plugin_model.rb +45 -0
- data/lib/poolparty/poolparty/pool.rb +76 -0
- data/lib/poolparty/poolparty/poolparty_base_class.rb +181 -0
- data/lib/poolparty/poolparty/resource.rb +205 -0
- data/lib/poolparty/poolparty/script.rb +58 -0
- data/lib/poolparty/poolparty/service.rb +34 -0
- data/lib/poolparty/poolparty/template.rb +27 -0
- data/lib/poolparty/provision/boot_strapper.rb +141 -0
- data/lib/poolparty/provision/configurations/chef.rb +22 -0
- data/lib/poolparty/provision/configurations/puppet.rb +28 -0
- data/lib/poolparty/provision/dr_configure.rb +85 -0
- data/lib/poolparty/resources/cron.rb +14 -0
- data/lib/poolparty/resources/custom_service.rb +30 -0
- data/lib/poolparty/resources/directory.rb +13 -0
- data/lib/poolparty/resources/exec.rb +25 -0
- data/lib/poolparty/resources/file.rb +29 -0
- data/lib/poolparty/resources/host.rb +16 -0
- data/lib/poolparty/resources/mount.rb +21 -0
- data/lib/poolparty/resources/package.rb +12 -0
- data/lib/poolparty/resources/remote_file.rb +20 -0
- data/lib/poolparty/resources/service.rb +20 -0
- data/lib/poolparty/resources/sshkey.rb +27 -0
- data/lib/poolparty/resources/symlink.rb +21 -0
- data/lib/poolparty/resources/user.rb +13 -0
- data/lib/poolparty/resources/variable.rb +9 -0
- data/lib/poolparty/schema.rb +64 -0
- data/lib/poolparty/services/conditional.rb +46 -0
- data/lib/poolparty/services/gem_package.rb +52 -0
- data/lib/poolparty/spec/core/string.rb +18 -0
- data/lib/poolparty/spec/matchers/a_spec_extensions_base.rb +26 -0
- data/lib/poolparty/spec/matchers/have_cron.rb +28 -0
- data/lib/poolparty/spec/matchers/have_deploydirectory.rb +15 -0
- data/lib/poolparty/spec/matchers/have_directory.rb +31 -0
- data/lib/poolparty/spec/matchers/have_exec.rb +28 -0
- data/lib/poolparty/spec/matchers/have_file.rb +28 -0
- data/lib/poolparty/spec/matchers/have_gempackage.rb +28 -0
- data/lib/poolparty/spec/matchers/have_git.rb +28 -0
- data/lib/poolparty/spec/matchers/have_host.rb +28 -0
- data/lib/poolparty/spec/matchers/have_mount.rb +28 -0
- data/lib/poolparty/spec/matchers/have_package.rb +28 -0
- data/lib/poolparty/spec/matchers/have_remotefile.rb +28 -0
- data/lib/poolparty/spec/matchers/have_rsyncmirror.rb +28 -0
- data/lib/poolparty/spec/matchers/have_service.rb +28 -0
- data/lib/poolparty/spec/matchers/have_sshkey.rb +28 -0
- data/lib/poolparty/spec/matchers/have_symlink.rb +28 -0
- data/lib/poolparty/spec/matchers/have_variable.rb +32 -0
- data/lib/poolparty/spec/spec/dynamic_matchers.rb +63 -0
- data/lib/poolparty/spec/spec/ensure_matchers_exist.rb +7 -0
- data/lib/poolparty/spec/templates/have_base.rb +28 -0
- data/lib/poolparty/spec.rb +31 -0
- data/lib/poolparty/templates/authkeys +2 -0
- data/lib/poolparty/templates/cib.xml +54 -0
- data/lib/poolparty/templates/erlang_cookie_maker +6 -0
- data/lib/poolparty/templates/gem +27 -0
- data/lib/poolparty/templates/gemrc +11 -0
- data/lib/poolparty/templates/ha.cf +17 -0
- data/lib/poolparty/templates/haproxy.conf +36 -0
- data/lib/poolparty/templates/haresources +3 -0
- data/lib/poolparty/templates/logd.cf +42 -0
- data/lib/poolparty/templates/messenger/client/log-run.erb +2 -0
- data/lib/poolparty/templates/messenger/client/run.erb +4 -0
- data/lib/poolparty/templates/messenger/master/log-run.erb +2 -0
- data/lib/poolparty/templates/messenger/master/run.erb +4 -0
- data/lib/poolparty/templates/messenger/node/log-run.erb +2 -0
- data/lib/poolparty/templates/messenger/node/run.erb +4 -0
- data/lib/poolparty/templates/monitor.ru +16 -0
- data/lib/poolparty/templates/namespaceauth.conf +19 -0
- data/lib/poolparty/templates/poolparty.monitor +14 -0
- data/lib/poolparty/templates/puppet/add_puppet_to_hosts +6 -0
- data/lib/poolparty/templates/puppet/puppet.conf +2 -0
- data/lib/poolparty/templates/puppet/puppetrunner +14 -0
- data/lib/poolparty/templates/puppet/site.pp +4 -0
- data/lib/poolparty/templates/puppetrunner +14 -0
- data/lib/poolparty/templates/yaws.conf +19 -0
- data/lib/poolparty/version.rb +15 -0
- data/lib/poolparty.rb +148 -0
- data/lib/poolpartycl.rb +7 -0
- data/script/destroy +14 -0
- data/script/generate +14 -0
- data/spec/bin/bin_spec_helper.rb +7 -0
- data/spec/bin/fixtures/bin_cloud_for_test.rb +19 -0
- data/spec/bin/server-list-active_spec.rb +22 -0
- data/spec/poolparty/aska/aska_spec.rb +117 -0
- data/spec/poolparty/base_packages/haproxy_spec.rb +7 -0
- data/spec/poolparty/base_packages/heartbeat_spec.rb +7 -0
- data/spec/poolparty/bin/console_spec.rb +83 -0
- data/spec/poolparty/core/array_spec.rb +46 -0
- data/spec/poolparty/core/float.rb +13 -0
- data/spec/poolparty/core/hash_spec.rb +83 -0
- data/spec/poolparty/core/kernel_spec.rb +24 -0
- data/spec/poolparty/core/module_spec.rb +15 -0
- data/spec/poolparty/core/object_spec.rb +68 -0
- data/spec/poolparty/core/ordered_hash_spec.rb +48 -0
- data/spec/poolparty/core/string_spec.rb +145 -0
- data/spec/poolparty/core/time_spec.rb +49 -0
- data/spec/poolparty/dependencies_spec.rb +11 -0
- data/spec/poolparty/dependency_resolver/chef_resolver_spec.rb +119 -0
- data/spec/poolparty/dependency_resolver/dependency_resolver_cloud_extensions_spec.rb +128 -0
- data/spec/poolparty/dependency_resolver/dependency_resolver_spec.rb +16 -0
- data/spec/poolparty/dependency_resolver/puppet_resolver_spec.rb +124 -0
- data/spec/poolparty/extra/deployments_spec.rb +68 -0
- data/spec/poolparty/fixtures/clouds.json +128 -0
- data/spec/poolparty/fixtures/test_template.erb +1 -0
- data/spec/poolparty/helpers/binary_spec.rb +26 -0
- data/spec/poolparty/helpers/display_spec.rb +13 -0
- data/spec/poolparty/helpers/hash_printer_spec.rb +34 -0
- data/spec/poolparty/helpers/optioner_spec.rb +50 -0
- data/spec/poolparty/id_rsa +27 -0
- data/spec/poolparty/modules/cloud_resourcer_spec.rb +67 -0
- data/spec/poolparty/modules/definable_resource.rb +9 -0
- data/spec/poolparty/modules/file_writer_spec.rb +64 -0
- data/spec/poolparty/modules/s3_string_spec.rb +15 -0
- data/spec/poolparty/monitors/base_monitor_spec.rb +112 -0
- data/spec/poolparty/monitors/monitors/cpu_monitor_spec.rb +18 -0
- data/spec/poolparty/monitors/monitors/memory_monitor_spec.rb +48 -0
- data/spec/poolparty/net/messenger_spec.rb +16 -0
- data/spec/poolparty/net/remote_instance_spec.rb +17 -0
- data/spec/poolparty/net/remote_spec.rb +286 -0
- data/spec/poolparty/net/remoter_base_spec.rb +35 -0
- data/spec/poolparty/net/remoter_bases/ec2_mocks_and_stubs.rb +24 -0
- data/spec/poolparty/net/remoter_bases/ec2_remote_instance_spec.rb +125 -0
- data/spec/poolparty/net/remoter_bases/ec2_spec.rb +119 -0
- data/spec/poolparty/net/remoter_spec.rb +130 -0
- data/spec/poolparty/plugins/chef_spec.rb +7 -0
- data/spec/poolparty/plugins/deploydirectory_spec.rb +51 -0
- data/spec/poolparty/plugins/git_spec.rb +40 -0
- data/spec/poolparty/plugins/line_spec.rb +22 -0
- data/spec/poolparty/plugins/svn_spec.rb +16 -0
- data/spec/poolparty/poolparty/cloud_spec.rb +345 -0
- data/spec/poolparty/poolparty/configurers/files/ruby_basic.rb +16 -0
- data/spec/poolparty/poolparty/configurers/files/ruby_plugins.rb +16 -0
- data/spec/poolparty/poolparty/configurers/ruby_spec.rb +42 -0
- data/spec/poolparty/poolparty/custom_resource_spec.rb +79 -0
- data/spec/poolparty/poolparty/default_spec.rb +139 -0
- data/spec/poolparty/poolparty/example_spec.rb +60 -0
- data/spec/poolparty/poolparty/key_spec.rb +42 -0
- data/spec/poolparty/poolparty/neighborhoods_spec.rb +66 -0
- data/spec/poolparty/poolparty/plugin_model_spec.rb +54 -0
- data/spec/poolparty/poolparty/plugin_spec.rb +41 -0
- data/spec/poolparty/poolparty/pool_spec.rb +100 -0
- data/spec/poolparty/poolparty/resource_spec.rb +209 -0
- data/spec/poolparty/poolparty/script_spec.rb +49 -0
- data/spec/poolparty/poolparty/service_spec.rb +5 -0
- data/spec/poolparty/poolparty/template_spec.rb +26 -0
- data/spec/poolparty/poolparty/test_plugins/sshkey_test +2 -0
- data/spec/poolparty/poolparty/test_plugins/virtual_host_template.erb +0 -0
- data/spec/poolparty/poolparty/test_plugins/webserver.rb +30 -0
- data/spec/poolparty/poolparty_base_class_spec.rb +80 -0
- data/spec/poolparty/poolparty_spec.rb +36 -0
- data/spec/poolparty/resources/cron_spec.rb +44 -0
- data/spec/poolparty/resources/directory_spec.rb +40 -0
- data/spec/poolparty/resources/exec_spec.rb +37 -0
- data/spec/poolparty/resources/file_spec.rb +63 -0
- data/spec/poolparty/resources/gem_spec.rb +7 -0
- data/spec/poolparty/resources/host_spec.rb +35 -0
- data/spec/poolparty/resources/package_spec.rb +29 -0
- data/spec/poolparty/resources/service_spec.rb +29 -0
- data/spec/poolparty/resources/sshkey_spec.rb +40 -0
- data/spec/poolparty/resources/symlink_spec.rb +29 -0
- data/spec/poolparty/resources/user_spec.rb +48 -0
- data/spec/poolparty/resources/variable_spec.rb +26 -0
- data/spec/poolparty/schema_spec.rb +53 -0
- data/spec/poolparty/services/conditional_spec.rb +52 -0
- data/spec/poolparty/spec/core/string_spec.rb +57 -0
- data/spec/poolparty/spec_helper.rb +263 -0
- data/spec/poolparty/test_spec_helper.rb +13 -0
- data/tasks/cloud.rake +3 -0
- data/tasks/development.rake +82 -0
- data/tasks/ec2.rake +13 -0
- data/tasks/environment.rake +7 -0
- data/tasks/instance.rake +2 -0
- data/tasks/poolparty.rake +54 -0
- data/tasks/server.rake +44 -0
- data/tasks/spec.rake +16 -0
- data/test/fixtures/test_template.erb +1 -0
- data/test/poolparty/core/hash_test.rb +23 -0
- data/test/poolparty/poolparty/template_test.rb +31 -0
- data/test/poolparty/provision/boot_strapper_test.rb +6 -0
- data/test/poolparty/provision/dr_configure_test.rb +6 -0
- data/test/test_generator_helper.rb +29 -0
- data/test/test_helper.rb +5 -0
- data/test/test_pool_spec_generator.rb +47 -0
- data/test/test_poolparty.rb +11 -0
- data/vendor/gems/butterfly/History.txt +4 -0
- data/vendor/gems/butterfly/PostInstall.txt +2 -0
- data/vendor/gems/butterfly/README.rdoc +48 -0
- data/vendor/gems/butterfly/Rakefile +62 -0
- data/vendor/gems/butterfly/VERSION.yml +4 -0
- data/vendor/gems/butterfly/bin/flutter +4 -0
- data/vendor/gems/butterfly/butterfly.gemspec +37 -0
- data/vendor/gems/butterfly/examples/config.ru +15 -0
- data/vendor/gems/butterfly/examples/my_app.rb +12 -0
- data/vendor/gems/butterfly/lib/butterfly.rb +14 -0
- data/vendor/gems/butterfly/lib/handler.rb +48 -0
- data/vendor/gems/butterfly/lib/request.rb +29 -0
- data/vendor/gems/butterfly/lib/response.rb +49 -0
- data/vendor/gems/butterfly/script/console +10 -0
- data/vendor/gems/butterfly/script/destroy +14 -0
- data/vendor/gems/butterfly/script/generate +14 -0
- data/vendor/gems/butterfly/test/test_adapter_base.rb +23 -0
- data/vendor/gems/butterfly/test/test_butterfly_request.rb +46 -0
- data/vendor/gems/butterfly/test/test_butterfly_response.rb +43 -0
- data/vendor/gems/butterfly/test/test_butterfly_server.rb +16 -0
- data/vendor/gems/butterfly/test/test_default.rb +12 -0
- data/vendor/gems/butterfly/test/test_helper.rb +6 -0
- data/vendor/gems/dslify/History.txt +4 -0
- data/vendor/gems/dslify/Manifest.txt +25 -0
- data/vendor/gems/dslify/PostInstall.txt +5 -0
- data/vendor/gems/dslify/README.txt +60 -0
- data/vendor/gems/dslify/Rakefile +56 -0
- data/vendor/gems/dslify/config/hoe.rb +73 -0
- data/vendor/gems/dslify/config/requirements.rb +15 -0
- data/vendor/gems/dslify/dslify.gemspec +40 -0
- data/vendor/gems/dslify/lib/dslify/dslify.rb +69 -0
- data/vendor/gems/dslify/lib/dslify/version.rb +10 -0
- data/vendor/gems/dslify/lib/dslify.rb +7 -0
- data/vendor/gems/dslify/script/console +10 -0
- data/vendor/gems/dslify/script/destroy +14 -0
- data/vendor/gems/dslify/script/generate +14 -0
- data/vendor/gems/dslify/script/txt2html +82 -0
- data/vendor/gems/dslify/setup.rb +1585 -0
- data/vendor/gems/dslify/tasks/deployment.rake +34 -0
- data/vendor/gems/dslify/tasks/environment.rake +7 -0
- data/vendor/gems/dslify/tasks/website.rake +17 -0
- data/vendor/gems/dslify/test/test_dslify.rb +114 -0
- data/vendor/gems/dslify/website/index.html +86 -0
- data/vendor/gems/dslify/website/index.txt +83 -0
- data/vendor/gems/dslify/website/javascripts/rounded_corners_lite.inc.js +285 -0
- data/vendor/gems/dslify/website/stylesheets/screen.css +138 -0
- data/vendor/gems/dslify/website/template.html.erb +48 -0
- data/vendor/gems/parenting/History.txt +4 -0
- data/vendor/gems/parenting/Manifest.txt +13 -0
- data/vendor/gems/parenting/PostInstall.txt +2 -0
- data/vendor/gems/parenting/README.rdoc +47 -0
- data/vendor/gems/parenting/Rakefile +28 -0
- data/vendor/gems/parenting/lib/parenting/base.rb +65 -0
- data/vendor/gems/parenting/lib/parenting.rb +10 -0
- data/vendor/gems/parenting/parenting.gemspec +39 -0
- data/vendor/gems/parenting/script/console +10 -0
- data/vendor/gems/parenting/script/destroy +14 -0
- data/vendor/gems/parenting/script/generate +14 -0
- data/vendor/gems/parenting/test/file_to_eval.rb +9 -0
- data/vendor/gems/parenting/test/test_helper.rb +5 -0
- data/vendor/gems/parenting/test/test_parenting.rb +89 -0
- data/vendor/gems/suitcase/LICENSE +20 -0
- data/vendor/gems/suitcase/README.rdoc +31 -0
- data/vendor/gems/suitcase/Rakefile +57 -0
- data/vendor/gems/suitcase/VERSION.yml +4 -0
- data/vendor/gems/suitcase/lib/suitcase/unzipper.rb +15 -0
- data/vendor/gems/suitcase/lib/suitcase/zipper.rb +103 -0
- data/vendor/gems/suitcase/lib/suitcase.rb +5 -0
- data/vendor/gems/suitcase/suitcase.gemspec +52 -0
- data/vendor/gems/suitcase/test/suitcase_test.rb +89 -0
- data/vendor/gems/suitcase/test/test_dir/box.rb +1 -0
- data/vendor/gems/suitcase/test/test_dir/test.txt +1 -0
- data/vendor/gems/suitcase/test/test_helper.rb +12 -0
- metadata +810 -0
data/History.txt
ADDED
@@ -0,0 +1,35 @@
|
|
1
|
+
== 1.0.0 2009-1-20
|
2
|
+
* Released 1.0 at CitrusByte
|
3
|
+
* Party
|
4
|
+
|
5
|
+
== 0.2.77 2008-12-5
|
6
|
+
* Added heartbeat failover
|
7
|
+
|
8
|
+
== 0.2.72
|
9
|
+
* Added specs to spec cloud
|
10
|
+
|
11
|
+
== 0.2.6 2008-10-14
|
12
|
+
* Maintaining the cloud
|
13
|
+
|
14
|
+
== 0.2 2008-09-02
|
15
|
+
* Finished new syntax rewrite
|
16
|
+
|
17
|
+
== 0.1.2 2008-08-05
|
18
|
+
* Added development tasks for easy setup
|
19
|
+
* Updated Scheduler to include ThreadPool for threaded safety
|
20
|
+
* Added poolnotify
|
21
|
+
* Updating gem on github
|
22
|
+
* Changed configuration style to rsync all files across every instance
|
23
|
+
* Moved configuration back to a configure scrip
|
24
|
+
* Added in vlad configuration
|
25
|
+
* Added plugin ability to install custom software
|
26
|
+
* Updated configuration style
|
27
|
+
* Added cloud_list to pool
|
28
|
+
* Changed listing of the clouds through pool
|
29
|
+
* Added plugin_manager
|
30
|
+
* Moved remoting to rake remote task (from vlad)
|
31
|
+
* Changed configuration from instance-based to cloud-based
|
32
|
+
* Updated source
|
33
|
+
* Plugin support
|
34
|
+
* Cleaned up base
|
35
|
+
* Extensible monitoring
|
data/License.txt
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
Copyright (c) 2009 Ari Lerner
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
a copy of this software and associated documentation files (the
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
the following conditions:
|
10
|
+
|
11
|
+
The above copyright notice and this permission notice shall be
|
12
|
+
included in all copies or substantial portions of the Software.
|
13
|
+
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/PostInstall.txt
ADDED
@@ -0,0 +1,19 @@
|
|
1
|
+
Get ready to jump in the pool, you just installed PoolParty! (Updated at 19:34 03/02/09)
|
2
|
+
|
3
|
+
To get started, run the generator:
|
4
|
+
|
5
|
+
pool spec <name>
|
6
|
+
|
7
|
+
Please check out the documentation for any questions or check out the google groups at
|
8
|
+
http://groups.google.com/group/poolpartyrb
|
9
|
+
|
10
|
+
More tutorials can be found at
|
11
|
+
http://poolpartyrb.com
|
12
|
+
|
13
|
+
Don't forget to check out the plugin tutorial @ http://poolpartyrb.com to extend PoolParty for your needs!
|
14
|
+
|
15
|
+
For more information, check http://PoolPartyrb.com or visit us on IRC at:
|
16
|
+
irc.freenode.net
|
17
|
+
#poolpartyrb
|
18
|
+
|
19
|
+
*** Ari Lerner @ <arilerner@mac.com> ***
|
data/README.txt
ADDED
@@ -0,0 +1,77 @@
|
|
1
|
+
= PoolParty
|
2
|
+
|
3
|
+
http://poolpartyrb.com
|
4
|
+
|
5
|
+
== DESCRIPTION:
|
6
|
+
|
7
|
+
PoolParty makes it easy and simple to configure any cloud of computers. In clear language, describe your cloud
|
8
|
+
with language such as:
|
9
|
+
|
10
|
+
pool :cloud do
|
11
|
+
cloud :app do
|
12
|
+
apache do
|
13
|
+
has_virtualhost(:name => "/var/www/sites/poolpartyrb.com")
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
== FEATURES/PROBLEMS:
|
19
|
+
|
20
|
+
* Written in Ruby and Erlang
|
21
|
+
* Written from the ground up to be extensible with plugins
|
22
|
+
* Easy git-style commands to communicate with your clouds
|
23
|
+
* Much much more
|
24
|
+
|
25
|
+
== SYNOPSIS:
|
26
|
+
|
27
|
+
PoolParty is written with the intention of being as application-agnostic as possible. It installs only the basic
|
28
|
+
required software to glue the cloud together on the instances as listed below.
|
29
|
+
|
30
|
+
PoolParty is easily configuration. In fact, it makes little assumptions about your development environment and allows
|
31
|
+
several options on how to begin configuring the cloud.
|
32
|
+
|
33
|
+
== REQUIREMENTS:
|
34
|
+
|
35
|
+
Ruby
|
36
|
+
Erlang
|
37
|
+
|
38
|
+
== INSTALL:
|
39
|
+
|
40
|
+
sudo gem install auser-poolparty
|
41
|
+
|
42
|
+
== TODO:
|
43
|
+
* Update hot reloading of puppet (force-reload?)
|
44
|
+
* Add pingback for nodes to master when failure occurs
|
45
|
+
* Add become master for the nodes
|
46
|
+
* Add hot reload to haproxy while reconfiguring
|
47
|
+
* Replace services with Runit
|
48
|
+
* Refactor provisioning to use erlang
|
49
|
+
* Add queuing of tasks on the messenger
|
50
|
+
* Add syntax checker on the manifests
|
51
|
+
* Move in collectd support
|
52
|
+
* Remove master-slave protocol
|
53
|
+
|
54
|
+
== LICENSE:
|
55
|
+
|
56
|
+
(The MIT License)
|
57
|
+
|
58
|
+
Copyright (c) 2008 Ari Lerner
|
59
|
+
|
60
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
61
|
+
a copy of this software and associated documentation files (the
|
62
|
+
'Software'), to deal in the Software without restriction, including
|
63
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
64
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
65
|
+
permit persons to whom the Software is furnished to do so, subject to
|
66
|
+
the following conditions:
|
67
|
+
|
68
|
+
The above copyright notice and this permission notice shall be
|
69
|
+
included in all copies or substantial portions of the Software.
|
70
|
+
|
71
|
+
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
72
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
73
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
74
|
+
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
75
|
+
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
76
|
+
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
77
|
+
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/Rakefile
ADDED
@@ -0,0 +1,45 @@
|
|
1
|
+
require 'config/requirements'
|
2
|
+
require 'config/jeweler' # setup gem configuration
|
3
|
+
|
4
|
+
Dir['tasks/**/*.rake'].each { |rake| load rake }
|
5
|
+
|
6
|
+
desc "Clean tmp directory"
|
7
|
+
task :clean_tmp do |t|
|
8
|
+
FileUtils.rm_rf("#{File.dirname(__FILE__)}/Manifest.txt") if ::File.exists?("#{File.dirname(__FILE__)}/Manifest.txt")
|
9
|
+
FileUtils.touch("#{File.dirname(__FILE__)}/Manifest.txt")
|
10
|
+
%w(logs tmp).each do |dir|
|
11
|
+
FileUtils.rm_rf("#{File.dirname(__FILE__)}/#{dir}") if ::File.exists?("#{File.dirname(__FILE__)}/#{dir}")
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
desc "Remove the pkg directory"
|
16
|
+
task :clean_pkg do |t|
|
17
|
+
%w(pkg).each do |dir|
|
18
|
+
FileUtils.rm_rf("#{File.dirname(__FILE__)}/#{dir}") if ::File.exists?("#{File.dirname(__FILE__)}/#{dir}")
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
desc "Packge with timestamp"
|
23
|
+
task :update_timestamp do
|
24
|
+
data = open("PostInstall.txt").read
|
25
|
+
str = "Updated at #{Time.now.strftime("%H:%M %D")}"
|
26
|
+
|
27
|
+
if data.scan(/Updated at/).empty?
|
28
|
+
data = data ^ {:updated_at => str}
|
29
|
+
else
|
30
|
+
data = data.gsub(/just installed PoolParty\!(.*)$/, "just installed PoolParty! (#{str})")
|
31
|
+
end
|
32
|
+
::File.open("PostInstall.txt", "w+") {|f| f << data }
|
33
|
+
end
|
34
|
+
|
35
|
+
namespace :gem do
|
36
|
+
task(:build).prerequisites.unshift :gemspec # Prepend the gemspec generation
|
37
|
+
|
38
|
+
desc "Build the gem only if the specs pass"
|
39
|
+
task :test_then_build => [:spec, :build]
|
40
|
+
|
41
|
+
desc "Build and install the gem only if the specs pass"
|
42
|
+
task :test_then_install => [:spec, :install]
|
43
|
+
end
|
44
|
+
|
45
|
+
task :release => [:update_timestamp]
|
data/VERSION.yml
ADDED
data/bin/cloud
ADDED
@@ -0,0 +1,32 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
# name = ARGV.select {|arg| arg if Binary.available_binaries_for("cloud").include?(arg) }.first
|
7
|
+
name = ARGV.shift if Binary.available_binaries_for("cloud").include?(ARGV.first)
|
8
|
+
# If the options include -h and they don't include a valid command, then we can just pass the
|
9
|
+
# original options back, but if they do contain a binary, we don't want -h getting through to
|
10
|
+
# these options, so we'll strip it if it's included
|
11
|
+
DUP_ARG = ARGV.dup
|
12
|
+
new_args = DUP_ARG.map {|arg| DUP_ARG.delete(arg) unless help_array.include?(arg) || Binary.available_binaries_for("cloud").include?(arg) }
|
13
|
+
new_args = new_args.reject {|arg| Binary.available_binaries_for("cloud").include?(arg) }.empty? ? ARGV : (name ? (help_array.each {|arg| DUP_ARG.delete(arg)}; DUP_ARG) : DUP_ARG)
|
14
|
+
|
15
|
+
# Let's make sure if no command is passed in that we show the help message
|
16
|
+
new_args.push("-h") unless name
|
17
|
+
|
18
|
+
o = PoolParty::Optioner.new(new_args, {:extra_help => "\nCloud actions\n#{Binary.list_binaries_for("cloud")}\n\n", :abstract => true}) do |opts, optioner|
|
19
|
+
opts.on('-n cloudname', '--name name', 'Address this cloud') { |c| optioner.cloudname c }
|
20
|
+
end
|
21
|
+
|
22
|
+
program_name = "#{File.basename($0)}-#{name}"
|
23
|
+
program_location = File.join(Binary.binary_directory, program_name)
|
24
|
+
|
25
|
+
command_line = "#{program_location}"
|
26
|
+
|
27
|
+
# Run it from the command-line first
|
28
|
+
if Binary.available_binaries_for("cloud").include?(name)
|
29
|
+
system command_line, *new_args
|
30
|
+
else
|
31
|
+
puts "Unknown poolparty binary: #{name}"
|
32
|
+
end
|
data/bin/cloud-bootstrap
ADDED
@@ -0,0 +1,21 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolparty/provision/boot_strapper"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n cloudname', '--name name', 'Start cloud by this name') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cld|
|
11
|
+
# If an IP or DNS name is given, bootstrap that node, otherwise, bootstrap all running nodes.
|
12
|
+
nodes = !o.unflagged_args.empty? ? o.unflagged_args : cld.running_instance_ips
|
13
|
+
if nodes.empty?
|
14
|
+
puts "No nodes to bootstrap"
|
15
|
+
else
|
16
|
+
nodes.each do |address|
|
17
|
+
puts "\nBootStrapping: #{address}\n--------------------"
|
18
|
+
::PoolParty::Provision::BootStrapper.new address, {:full_keypair_path => cld.keypair.full_filepath, :cloud => cld}
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
data/bin/cloud-configure
ADDED
@@ -0,0 +1,28 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
# require "poolpartycl"
|
5
|
+
|
6
|
+
|
7
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
8
|
+
opts.on('-n cloudname', '--name name', 'Start cloud by this name') { |c| optioner.cloudname c }
|
9
|
+
opts.on('-i num', '--num i', 'Instance number') { |i| optioner.inst_num i.to_i }
|
10
|
+
end
|
11
|
+
|
12
|
+
o.loaded_clouds.each do |cld|
|
13
|
+
# If an IP or DNS name is given, bootstrap that node, otherwise, bootstrap all running nodes.
|
14
|
+
nodes = !o.unflagged_args.empty? ? o.unflagged_args : cld.remote_instances_list.collect {|inst| inst.ip if inst.running? }.compact
|
15
|
+
if nodes.empty?
|
16
|
+
puts "No nodes to configure"
|
17
|
+
else
|
18
|
+
if o.inst_num?
|
19
|
+
::PoolParty::Provision::DrConfigure.new( nodes[o.inst_num], :full_keypair_path => cld.keypair.full_filepath, :cloud => cld )
|
20
|
+
else
|
21
|
+
nodes.each do |address|
|
22
|
+
puts "Configuring: #{address}"
|
23
|
+
::PoolParty::Provision::DrConfigure.new( address, :full_keypair_path => cld.keypair.full_filepath, :cloud => cld )
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
data/bin/cloud-console
ADDED
@@ -0,0 +1,12 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# File: script/console
|
3
|
+
irb = RUBY_PLATFORM =~ /(:?mswin|mingw)/ ? 'irb.bat' : 'irb'
|
4
|
+
|
5
|
+
libs = " -r irb/completion"
|
6
|
+
# Perhaps use a console_lib to store any extra methods I may want available in the cosole
|
7
|
+
# libs << " -r #{File.dirname(__FILE__) + '/../lib/console_lib/console_logger.rb'}"
|
8
|
+
libs << " -r #{File.dirname(__FILE__) + '/../lib/poolparty.rb'}"
|
9
|
+
libs << " -r #{File.dirname(__FILE__) + '/../lib/poolpartycl.rb'}"
|
10
|
+
puts "Loading PoolParty console..."
|
11
|
+
|
12
|
+
exec "#{irb} #{libs} --simple-prompt"
|
data/bin/cloud-contract
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cl|
|
11
|
+
with_cloud(cl) do
|
12
|
+
puts header("Contracting cloud #{name}")
|
13
|
+
puts "#{list_of_running_instances.size} running instances (#{minimum_instances} minimum instances)"
|
14
|
+
puts testing ? "Not contracting (test mode)" : "Contracting the cloud if possible"
|
15
|
+
contract_cloud_if_necessary( !testing )
|
16
|
+
end
|
17
|
+
end
|
data/bin/cloud-expand
ADDED
@@ -0,0 +1,19 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Expand the cloud on this name') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cloud|
|
11
|
+
|
12
|
+
with_cloud(cloud) do
|
13
|
+
vputs header("Expanding cloud #{name}")
|
14
|
+
vputs "#{list_of_running_instances.size} running instances of #{maximum_instances} possible instances"
|
15
|
+
vputs testing ? "Not expanding (test mode)" : "Expanding the cloud"
|
16
|
+
expand_cloud_if_necessary( !testing )
|
17
|
+
end
|
18
|
+
|
19
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cloud|
|
11
|
+
|
12
|
+
with_cloud(cloud) do
|
13
|
+
vputs header("Load handling cloud #{name}")
|
14
|
+
vputs "can_expand_cloud: #{can_contract_cloud?}"
|
15
|
+
if can_expand_cloud?
|
16
|
+
vputs "Expanding cloud based on load"
|
17
|
+
log.debug "Expanding cloud based on load"
|
18
|
+
log.debug rules_values
|
19
|
+
expand_cloud_if_necessary
|
20
|
+
elsif can_contract_cloud?
|
21
|
+
vputs "Contracting cloud based on load"
|
22
|
+
log.debug rules_values
|
23
|
+
contract_cloud_if_necessary
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
data/bin/cloud-list
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
|
5
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
6
|
+
opts.on('-f [remote|local]', '--from [remote|local]', 'Remote or local (default: local)') { |o| optioner.location o }
|
7
|
+
opts.on('-r', '--remote', 'Remote listing') { optioner.location "remote" }
|
8
|
+
opts.on('-l', '--local', 'Local listing') { optioner.location "local" }
|
9
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
10
|
+
end
|
11
|
+
|
12
|
+
o.loaded_clouds.each do |cld|
|
13
|
+
|
14
|
+
puts header("Listing cloud #{cld.name}")
|
15
|
+
|
16
|
+
puts subheader("Active instances")
|
17
|
+
puts cld.list_of_running_instances.map{|a| a.to_s}.join("\n")
|
18
|
+
|
19
|
+
if cld.list_of_pending_instances.size > 0
|
20
|
+
puts subheader("Pending instances")
|
21
|
+
puts cld.list_of_pending_instances.map{|a| a.to_s}.join("\n")
|
22
|
+
end
|
23
|
+
end
|
data/bin/cloud-osxcopy
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Copy the master ip for this cloud') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cld|
|
11
|
+
|
12
|
+
node = cld.list_of_running_instances.first
|
13
|
+
ip = node.ip
|
14
|
+
puts "ip: #{ip}"
|
15
|
+
Kernel.system "echo #{ip} | pbcopy"
|
16
|
+
|
17
|
+
end
|
data/bin/cloud-provision
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolparty/provision/boot_strapper"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n cloudname', '--name name', 'Start cloud by this name') { |c| optioner.cloudname c }
|
8
|
+
opts.on('-i num', '--num i', 'Instance number') { |i| optioner.inst_num i.to_i }
|
9
|
+
end
|
10
|
+
|
11
|
+
o.loaded_clouds.each do |cld|
|
12
|
+
# If an IP or DNS name is given, bootstrap that node, otherwise, bootstrap all running nodes.
|
13
|
+
nodes = !o.unflagged_args.empty? ? o.unflagged_args : cld.remote_instances_list.collect {|inst| inst.ip if inst.running? }.compact
|
14
|
+
if nodes.empty?
|
15
|
+
puts "No nodes to bootstrap"
|
16
|
+
else
|
17
|
+
if o.inst_num?
|
18
|
+
::PoolParty::Provision::BootStrapper.new( nodes[o.inst_num], :full_keypair_path => cld.keypair.full_filepath, :cloud => cld )
|
19
|
+
::PoolParty::Provision::DrConfigure.new( nodes[o.inst_num], :full_keypair_path => cld.keypair.full_filepath, :cloud => cld )
|
20
|
+
else
|
21
|
+
nodes.each do |address|
|
22
|
+
puts "bootstrapping: #{address}"
|
23
|
+
::PoolParty::Provision::BootStrapper.new( address, :full_keypair_path => cld.keypair.full_filepath, :cloud => cld )
|
24
|
+
::PoolParty::Provision::DrConfigure.new( address, :full_keypair_path => cld.keypair.full_filepath,
|
25
|
+
:cloud => cld )
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
data/bin/cloud-rsync
ADDED
@@ -0,0 +1,28 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV, {:extra_help => "\nUsage: cloud [options] rsync source target\n\n"}) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
8
|
+
opts.on('-i num', '--id num', 'Instance num to ssh (default: 0)') { |i| optioner.num i }
|
9
|
+
end
|
10
|
+
|
11
|
+
@instance_number = (o.num || 0 ).to_i
|
12
|
+
|
13
|
+
if o.unflagged_args.length > 1
|
14
|
+
@target = o.unflagged_args.pop
|
15
|
+
@source = o.unflagged_args.pop
|
16
|
+
else
|
17
|
+
@source = o.unflagged_args.pop
|
18
|
+
@target = ''
|
19
|
+
end
|
20
|
+
|
21
|
+
o.loaded_clouds.each do |cloud|
|
22
|
+
|
23
|
+
with_cloud(cloud, {:source=>@source, :target=>@target, :instance_number=>@instance_number }) do
|
24
|
+
puts header("rsyncing")
|
25
|
+
rsync_to source, target, instance_number
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
data/bin/cloud-run
ADDED
@@ -0,0 +1,18 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
@cmd = ARGV[-1]
|
7
|
+
|
8
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
9
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
10
|
+
opts.on('-i num', '--id num', 'Instance num to ssh (default: 0)') { |i| optioner.num i }
|
11
|
+
opts.on('-c command', '--command command', 'Command to run on the instance') { |c| optioner.command c }
|
12
|
+
end
|
13
|
+
|
14
|
+
@cmd = o.command if (o.command)
|
15
|
+
|
16
|
+
o.loaded_clouds.each do |cl|
|
17
|
+
@cloud.run_command_on_instance_number( @cmd, o.num.to_i || 0 ) if @cloud
|
18
|
+
end
|
data/bin/cloud-setup-dev
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Setup development environment for cloud named') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cld|
|
11
|
+
|
12
|
+
if cld.remote_instances_list.empty?
|
13
|
+
puts "Your cloud is not running"
|
14
|
+
else
|
15
|
+
str =<<-EOE
|
16
|
+
Host #{cld.name}-master
|
17
|
+
User #{cld.user}
|
18
|
+
Hostname #{cld.remote_instances_list.first.ip}
|
19
|
+
IdentityFile #{cld.keypair}
|
20
|
+
EOE
|
21
|
+
|
22
|
+
puts "Enter the following in your .ssh/config file"
|
23
|
+
puts str
|
24
|
+
end
|
25
|
+
end
|
data/bin/cloud-show
ADDED
@@ -0,0 +1,27 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
|
5
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
6
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
7
|
+
end
|
8
|
+
|
9
|
+
o.loaded_clouds.each do |cld|
|
10
|
+
|
11
|
+
print_with_nice_printer "Cloud: #{cld.name}", [
|
12
|
+
"instances #{cld.minimum_instances}..#{cld.maximum_instances}",
|
13
|
+
"keypair #{cld.keypair}"
|
14
|
+
] do |printer|
|
15
|
+
if cld.list_of_running_instances.size > 0
|
16
|
+
printer.empty
|
17
|
+
printer.center("Active instances")
|
18
|
+
printer << cld.list_of_running_instances.map{|a| a.ip.strip }.join("\n")
|
19
|
+
end
|
20
|
+
if cld.list_of_pending_instances.size > 0
|
21
|
+
printer.empty
|
22
|
+
printer.center "Pending instances"
|
23
|
+
printer << cld.list_of_pending_instances.map{|a| a.to_s}.join("\n")
|
24
|
+
end
|
25
|
+
printer.empty
|
26
|
+
end
|
27
|
+
end
|
data/bin/cloud-spec
ADDED
@@ -0,0 +1,41 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
available_tests = {
|
7
|
+
:launch => "Launches a cloud and ensures it is accessible at port 80"
|
8
|
+
}
|
9
|
+
|
10
|
+
available_tests_string = available_tests.map {|k,v| "#{k}: #{v}"}.join("\n")
|
11
|
+
|
12
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
13
|
+
optioner.cloudnames
|
14
|
+
optioner.daemonizeable
|
15
|
+
opts.on('--type type',
|
16
|
+
"Run type of test. Available tests: #{available_tests_string} (default: launch)") { |c| optioner.testtype c }
|
17
|
+
end
|
18
|
+
|
19
|
+
o.loaded_clouds.each do |cloud|
|
20
|
+
with_cloud(cloud) do
|
21
|
+
puts "Are you sure you want to live test?"
|
22
|
+
body = ["Normal charges for running instances will apply"]
|
23
|
+
body << "as this will run instances"
|
24
|
+
body.each {|st| puts "\t#{st}"}
|
25
|
+
print "(y|n): "
|
26
|
+
input = gets.downcase.chomp
|
27
|
+
do_test = input.downcase == "y" ? true : false
|
28
|
+
if do_test
|
29
|
+
case testtype
|
30
|
+
when "launch"
|
31
|
+
when nil
|
32
|
+
print_with_nice_printer("Starting live specing cloud #{name}")
|
33
|
+
puts "TODO: this isn't implented yet."
|
34
|
+
# hide_output {launch_and_configure_master!}
|
35
|
+
print_with_nice_printer("Waiting for cloud to provision")
|
36
|
+
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
end
|
data/bin/cloud-ssh
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
optioner.options( :num => 0 )
|
8
|
+
opts.on('-n name', '--name name', 'Listing for cloud name') { |c| optioner.cloudname c }
|
9
|
+
opts.on('-i num', '--id num', 'Instance num to ssh (default: 0)') { |i| optioner.inst_num i.to_i }
|
10
|
+
end
|
11
|
+
load_pool(o.spec? ? o.spec : Binary.get_existing_spec_location)
|
12
|
+
|
13
|
+
@cloud = o.loaded_clouds.first
|
14
|
+
nodes = @cloud.list_of_running_instances
|
15
|
+
|
16
|
+
puts nodes.map {|a| a.to_s}.join("\n")
|
17
|
+
|
18
|
+
if !nodes.empty?
|
19
|
+
n = o.inst_num? ? o.inst_num : 0
|
20
|
+
@cloud.ssh_into( nodes[n].ip ) if @cloud
|
21
|
+
else
|
22
|
+
puts "No running instances can be found"
|
23
|
+
end
|
data/bin/cloud-start
ADDED
@@ -0,0 +1,28 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
|
5
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
6
|
+
opts.on('-n cloudname', '--name name', 'Start cloud by this name') { |c| optioner.cloudname c }
|
7
|
+
end
|
8
|
+
|
9
|
+
o.loaded_clouds.each do |cld|
|
10
|
+
if cld.list_of_running_instances.size.zero?
|
11
|
+
puts header("Starting cloud #{cld.name}")
|
12
|
+
puts "#{cld.list_of_running_instances.size} running instances (#{cld.minimum_instances} - #{cld.maximum_instances})"
|
13
|
+
|
14
|
+
cld.launch_instance! do |node|
|
15
|
+
::PoolParty::Provision::BootStrapper.new(node.ip, :full_keypair_path => cld.keypair.full_filepath, :cloud => cld)
|
16
|
+
::PoolParty::Provision::DrConfigure.new(node.ip, :full_keypair_path => cld.keypair.full_filepath, :cloud => cld)
|
17
|
+
|
18
|
+
puts <<-EOM
|
19
|
+
Your cloud has started. Your ip is #{node.ip}
|
20
|
+
EOM
|
21
|
+
end
|
22
|
+
|
23
|
+
else
|
24
|
+
puts <<-EOE
|
25
|
+
Your cloud is already running.
|
26
|
+
EOE
|
27
|
+
end
|
28
|
+
end
|
data/bin/cloud-stats
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
$:.unshift(File.join(File.dirname(__FILE__), "..", "lib"))
|
3
|
+
require "poolparty"
|
4
|
+
require "poolpartycl"
|
5
|
+
|
6
|
+
o = PoolParty::Optioner.new(ARGV) do |opts, optioner|
|
7
|
+
opts.on('-n name', '--name name', 'Stats for cloud name') { |c| optioner.cloudname c }
|
8
|
+
end
|
9
|
+
|
10
|
+
o.loaded_clouds.each do |cloud|
|
11
|
+
|
12
|
+
with_cloud(cloud) do
|
13
|
+
puts header("#{name.to_s.capitalize} cloud stats")
|
14
|
+
run_command_on(". /etc/profile && server-show-stats", master)
|
15
|
+
end
|
16
|
+
|
17
|
+
end
|