ufo 5.0.7 → 6.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.cody/README.md +19 -0
- data/.cody/acceptance/bin/build.sh +90 -0
- data/.cody/acceptance/buildspec.yml +10 -0
- data/.cody/acceptance/project.rb +11 -0
- data/.cody/acceptance/role.rb +28 -0
- data/.cody/shared/script/install/ufo.sh +40 -0
- data/.cody/shared/script/install.sh +5 -0
- data/.github/workflows/main.yml +28 -0
- data/CHANGELOG.md +4 -1
- data/Gemfile +0 -2
- data/README.md +1 -32
- data/lib/templates/docker/Dockerfile +4 -0
- data/lib/templates/helper/%underscore_name%_helper.rb.tt +6 -0
- data/lib/templates/init/.ufo/config/web/base.rb +6 -0
- data/lib/templates/init/.ufo/config/web/dev.rb +6 -0
- data/lib/templates/init/.ufo/config/web/prod.rb +6 -0
- data/lib/templates/init/.ufo/config.rb.tt +39 -0
- data/lib/templates/init/.ufo/resources/iam_roles/execution_role.rb +23 -0
- data/lib/templates/init/.ufo/resources/iam_roles/task_role.rb +20 -0
- data/lib/templates/init/.ufo/resources/task_definitions/web.yml +29 -0
- data/lib/templates/init/.ufo/vars/base.rb +20 -0
- data/lib/templates/init/.ufo/vars/dev.rb +4 -0
- data/lib/templates/init/.ufo/vars/prod.rb +4 -0
- data/lib/ufo/aws_services.rb +118 -0
- data/lib/ufo/booter.rb +27 -0
- data/lib/ufo/cfn/base.rb +7 -0
- data/lib/ufo/cfn/deploy.rb +54 -0
- data/lib/ufo/{stack → cfn/stack}/builder/base.rb +12 -23
- data/lib/ufo/cfn/stack/builder/conditions.rb +25 -0
- data/lib/ufo/{stack → cfn/stack}/builder/outputs.rb +2 -2
- data/lib/ufo/cfn/stack/builder/parameters.rb +34 -0
- data/lib/ufo/cfn/stack/builder/resources/base.rb +4 -0
- data/lib/ufo/cfn/stack/builder/resources/dns.rb +47 -0
- data/lib/ufo/{stack/builder/resources/ecs.rb → cfn/stack/builder/resources/ecs_service.rb} +11 -10
- data/lib/ufo/cfn/stack/builder/resources/elb.rb +35 -0
- data/lib/ufo/cfn/stack/builder/resources/iam_roles/base.rb +32 -0
- data/lib/ufo/cfn/stack/builder/resources/iam_roles/execution_role.rb +4 -0
- data/lib/ufo/cfn/stack/builder/resources/iam_roles/task_role.rb +4 -0
- data/lib/ufo/cfn/stack/builder/resources/listener.rb +65 -0
- data/lib/ufo/cfn/stack/builder/resources/listener_ssl.rb +44 -0
- data/lib/ufo/cfn/stack/builder/resources/scaling/base.rb +5 -0
- data/lib/ufo/cfn/stack/builder/resources/scaling/policy.rb +27 -0
- data/lib/ufo/cfn/stack/builder/resources/scaling/role.rb +33 -0
- data/lib/ufo/cfn/stack/builder/resources/scaling/target.rb +22 -0
- data/lib/ufo/cfn/stack/builder/resources/security_group/base.rb +4 -0
- data/lib/ufo/{stack → cfn/stack}/builder/resources/security_group/ecs.rb +4 -4
- data/lib/ufo/{stack → cfn/stack}/builder/resources/security_group/ecs_rule.rb +2 -2
- data/lib/ufo/{stack → cfn/stack}/builder/resources/security_group/elb.rb +5 -6
- data/lib/ufo/{stack → cfn/stack}/builder/resources/target_group.rb +4 -4
- data/lib/ufo/{stack → cfn/stack}/builder/resources/task_definition/reconstructor.rb +4 -4
- data/lib/ufo/{stack → cfn/stack}/builder/resources/task_definition.rb +4 -4
- data/lib/ufo/cfn/stack/builder/resources.rb +24 -0
- data/lib/ufo/cfn/stack/builder.rb +30 -0
- data/lib/ufo/{stack → cfn/stack}/custom_properties.rb +21 -5
- data/lib/ufo/cfn/stack/params.rb +51 -0
- data/lib/ufo/{stack → cfn/stack}/status.rb +2 -2
- data/lib/ufo/cfn/stack/template.rb +8 -0
- data/lib/ufo/cfn/stack/vars.rb +110 -0
- data/lib/ufo/cfn/stack/vpc.rb +31 -0
- data/lib/ufo/cfn/stack.rb +175 -0
- data/lib/ufo/cli/base.rb +18 -0
- data/lib/ufo/cli/build.rb +30 -0
- data/lib/ufo/cli/cancel.rb +18 -0
- data/lib/ufo/cli/central/update.rb +80 -0
- data/lib/ufo/cli/central.rb +12 -0
- data/lib/ufo/cli/clean.rb +17 -0
- data/lib/ufo/cli/destroy.rb +31 -0
- data/lib/ufo/{docker.rb → cli/docker.rb} +18 -18
- data/lib/ufo/cli/exec.rb +82 -0
- data/lib/ufo/cli/help/central/update.md +20 -0
- data/lib/ufo/{help → cli/help}/completion.md +0 -0
- data/lib/ufo/{help → cli/help}/completion_script.md +0 -0
- data/lib/ufo/cli/help/destroy.md +9 -0
- data/lib/ufo/cli/help/docker/base.md +39 -0
- data/lib/ufo/{help → cli/help}/docker/build.md +9 -9
- data/lib/ufo/{help → cli/help}/docker/clean.md +8 -8
- data/lib/ufo/{help → cli/help}/docker/compile.md +0 -0
- data/lib/ufo/cli/help/docker/name.md +16 -0
- data/lib/ufo/{help → cli/help}/docker/push.md +0 -0
- data/lib/ufo/cli/help/docker.md +6 -0
- data/lib/ufo/{help → cli/help}/help.md +1 -1
- data/lib/ufo/cli/help/init.md +27 -0
- data/lib/ufo/{help → cli/help}/logs.md +5 -4
- data/lib/ufo/cli/help/ps.md +12 -0
- data/lib/ufo/cli/help/releases.md +15 -0
- data/lib/ufo/cli/help/rollback.md +40 -0
- data/lib/ufo/cli/help/scale.md +7 -0
- data/lib/ufo/cli/help/ship.md +41 -0
- data/lib/ufo/cli/help/stop.md +3 -0
- data/lib/ufo/cli/help.rb +62 -0
- data/lib/ufo/{logs.rb → cli/logs.rb} +13 -6
- data/lib/ufo/cli/new/concerns.rb +16 -0
- data/lib/ufo/cli/new/helper.rb +24 -0
- data/lib/ufo/cli/new/init.rb +68 -0
- data/lib/ufo/{sequence.rb → cli/new/sequence.rb} +26 -4
- data/lib/ufo/cli/new.rb +10 -0
- data/lib/ufo/cli/opts.rb +35 -0
- data/lib/ufo/{ps → cli/ps}/task.rb +22 -29
- data/lib/ufo/cli/ps.rb +190 -0
- data/lib/ufo/{releases.rb → cli/releases.rb} +4 -4
- data/lib/ufo/{rollback.rb → cli/rollback.rb} +24 -12
- data/lib/ufo/cli/scale.rb +76 -0
- data/lib/ufo/cli/ship.rb +28 -0
- data/lib/ufo/cli/status.rb +8 -0
- data/lib/ufo/cli/stop.rb +49 -0
- data/lib/ufo/{tasks.rb → cli/tasks.rb} +2 -2
- data/lib/ufo/{upgrade.rb → cli/upgrade.rb} +2 -2
- data/lib/ufo/cli.rb +82 -172
- data/lib/ufo/command.rb +56 -1
- data/lib/ufo/concerns/autoscaling.rb +11 -0
- data/lib/ufo/concerns/names.rb +9 -0
- data/lib/ufo/concerns.rb +26 -0
- data/lib/ufo/config/inits.rb +13 -0
- data/lib/ufo/config.rb +187 -0
- data/lib/ufo/core.rb +32 -44
- data/lib/ufo/docker/builder.rb +44 -40
- data/lib/ufo/docker/cleaner.rb +9 -12
- data/lib/ufo/docker/compiler.rb +10 -4
- data/lib/ufo/docker/concerns.rb +7 -0
- data/lib/ufo/docker/dockerfile.rb +13 -9
- data/lib/ufo/docker/pusher.rb +13 -25
- data/lib/ufo/docker/state.rb +63 -0
- data/lib/ufo/ecr/auth.rb +8 -7
- data/lib/ufo/ecr/cleaner.rb +10 -14
- data/lib/ufo/ext/core/module.rb +31 -0
- data/lib/ufo/ext/core/nil_class.rb +11 -0
- data/lib/ufo/ext.rb +2 -0
- data/lib/ufo/{role → iam_role}/builder.rb +1 -1
- data/lib/ufo/{role → iam_role}/dsl.rb +8 -2
- data/lib/ufo/{role → iam_role}/registry.rb +1 -1
- data/lib/ufo/info.rb +22 -4
- data/lib/ufo/layering/layer.rb +95 -0
- data/lib/ufo/layering.rb +23 -0
- data/lib/ufo/log_group.rb +18 -10
- data/lib/ufo/logger/formatter.rb +13 -0
- data/lib/ufo/logger.rb +32 -0
- data/lib/ufo/names.rb +69 -0
- data/lib/ufo/param.rb +2 -1
- data/lib/ufo/task_definition/builder.rb +7 -0
- data/lib/ufo/task_definition/context.rb +45 -0
- data/lib/ufo/task_definition/erb/base.rb +18 -0
- data/lib/ufo/task_definition/erb/json.rb +28 -0
- data/lib/ufo/task_definition/erb/yaml.rb +18 -0
- data/lib/ufo/task_definition/erb.rb +78 -0
- data/lib/ufo/task_definition/helpers/aws_data_helper.rb +18 -0
- data/lib/ufo/task_definition/helpers/core.rb +50 -0
- data/lib/ufo/task_definition/helpers/ssm/fetcher.rb +39 -0
- data/lib/ufo/task_definition/helpers/ssm.rb +8 -0
- data/lib/ufo/task_definition/helpers/stack_output.rb +23 -0
- data/lib/ufo/{dsl/helper → task_definition/helpers}/vars.rb +40 -19
- data/lib/ufo/task_definition/helpers/vpc.rb +48 -0
- data/lib/ufo/task_definition/helpers.rb +5 -0
- data/lib/ufo/task_definition.rb +19 -0
- data/lib/ufo/upgrade/upgrade3.rb +1 -1
- data/lib/ufo/upgrade/upgrade4.rb +3 -3
- data/lib/ufo/utils/execute.rb +30 -0
- data/lib/ufo/utils/logging.rb +7 -0
- data/lib/ufo/utils/pretty.rb +18 -0
- data/lib/ufo/utils/squeezer.rb +1 -1
- data/lib/ufo/utils/sure.rb +23 -0
- data/lib/ufo/version.rb +1 -1
- data/lib/ufo/yaml/loader.rb +48 -0
- data/lib/ufo/yaml/validator.rb +51 -0
- data/lib/ufo/yaml.rb +13 -0
- data/lib/ufo.rb +12 -2
- data/spec/spec_helper.rb +4 -26
- data/spec/{lib → ufo}/ecr_auth_spec.rb +0 -0
- data/spec/{lib → ufo}/ecr_cleaner_spec.rb +0 -2
- data/spec/{lib/role → ufo/iam_role}/builder_spec.rb +5 -5
- data/spec/{lib/role → ufo/iam_role}/dsl_spec.rb +3 -3
- data/spec/{lib → ufo}/logs_spec.rb +2 -2
- data/ufo.gemspec +9 -3
- metadata +244 -341
- data/.circleci/bin/commit_docs.sh +0 -26
- data/.circleci/config.yml +0 -78
- data/.gitmodules +0 -0
- data/docs/.gitignore +0 -5
- data/docs/CNAME +0 -1
- data/docs/Gemfile +0 -4
- data/docs/LICENSE +0 -21
- data/docs/README.md +0 -20
- data/docs/_config.yml +0 -75
- data/docs/_docs/aws-ecs-task-execution-role.md +0 -28
- data/docs/_docs/conventions.md +0 -47
- data/docs/_docs/extras/codebuild-iam-role.md +0 -46
- data/docs/_docs/extras/dockerfile-erb.md +0 -60
- data/docs/_docs/extras/ecs-network-mode.md +0 -37
- data/docs/_docs/extras/load-balancer.md +0 -83
- data/docs/_docs/extras/minimal-deploy-iam.md +0 -79
- data/docs/_docs/extras/notification-arns.md +0 -21
- data/docs/_docs/extras/redirection-support.md +0 -27
- data/docs/_docs/extras/route53-support.md +0 -27
- data/docs/_docs/extras/security-groups.md +0 -36
- data/docs/_docs/extras/ssl-support.md +0 -20
- data/docs/_docs/faq.md +0 -100
- data/docs/_docs/fargate.md +0 -5
- data/docs/_docs/helpers.md +0 -24
- data/docs/_docs/iam-roles.md +0 -112
- data/docs/_docs/install.md +0 -25
- data/docs/_docs/more/auto-completion.md +0 -24
- data/docs/_docs/more/automated-cleanup.md +0 -14
- data/docs/_docs/more/customize-cloudformation.md +0 -35
- data/docs/_docs/more/migrations.md +0 -25
- data/docs/_docs/more/run-in-pieces.md +0 -30
- data/docs/_docs/more/single-task.md +0 -25
- data/docs/_docs/more/stuck-cloudformation.md +0 -29
- data/docs/_docs/more/why-cloudformation.md +0 -21
- data/docs/_docs/next-steps.md +0 -16
- data/docs/_docs/quick-start-ec2.md +0 -86
- data/docs/_docs/secrets.md +0 -135
- data/docs/_docs/settings/aws_profile.md +0 -36
- data/docs/_docs/settings/cfn.md +0 -12
- data/docs/_docs/settings/cluster.md +0 -66
- data/docs/_docs/settings/manage-security-groups.md +0 -24
- data/docs/_docs/settings/network.md +0 -45
- data/docs/_docs/settings.md +0 -55
- data/docs/_docs/ssl_errors.md +0 -40
- data/docs/_docs/structure.md +0 -41
- data/docs/_docs/tutorial-ufo-docker-build.md +0 -61
- data/docs/_docs/tutorial-ufo-init.md +0 -86
- data/docs/_docs/tutorial-ufo-ship.md +0 -95
- data/docs/_docs/tutorial-ufo-ships.md +0 -38
- data/docs/_docs/tutorial-ufo-tasks-build.md +0 -177
- data/docs/_docs/tutorial.md +0 -14
- data/docs/_docs/ufo-current.md +0 -49
- data/docs/_docs/ufo-env-extra.md +0 -22
- data/docs/_docs/ufo-env.md +0 -46
- data/docs/_docs/ufo-logs.md +0 -49
- data/docs/_docs/ufo-task-params.md +0 -43
- data/docs/_docs/ufo-tasks-register.md +0 -21
- data/docs/_docs/upgrading/upgrade4.5.md +0 -52
- data/docs/_docs/upgrading/upgrade4.md +0 -48
- data/docs/_docs/upgrading/upgrade5.md +0 -19
- data/docs/_docs/upgrading.md +0 -13
- data/docs/_docs/variables.md +0 -55
- data/docs/_includes/about.html +0 -19
- data/docs/_includes/banner/foot.html +0 -2
- data/docs/_includes/banner/head.html +0 -5
- data/docs/_includes/cfn-customize.md +0 -53
- data/docs/_includes/commands.html +0 -80
- data/docs/_includes/contact.html +0 -17
- data/docs/_includes/contact_disqus.html +0 -16
- data/docs/_includes/contact_static.html +0 -17
- data/docs/_includes/content.html +0 -26
- data/docs/_includes/css/bootstrap.min.css +0 -7
- data/docs/_includes/css/main.css +0 -501
- data/docs/_includes/css/quotes.css +0 -102
- data/docs/_includes/css/syntax.css +0 -65
- data/docs/_includes/css/table.css +0 -53
- data/docs/_includes/css/timeline.css +0 -201
- data/docs/_includes/css/ufo.css +0 -218
- data/docs/_includes/edit-on-github.html +0 -11
- data/docs/_includes/example.html +0 -63
- data/docs/_includes/footer.html +0 -44
- data/docs/_includes/google_analytics.html +0 -10
- data/docs/_includes/head.html +0 -32
- data/docs/_includes/header.html +0 -15
- data/docs/_includes/js.html +0 -32
- data/docs/_includes/js_disqus.html +0 -21
- data/docs/_includes/modals.html +0 -40
- data/docs/_includes/nav.html +0 -27
- data/docs/_includes/prev_next.md +0 -19
- data/docs/_includes/quotes.html +0 -19
- data/docs/_includes/reference.md +0 -5
- data/docs/_includes/repo_push_access.md +0 -11
- data/docs/_includes/subnav.html +0 -78
- data/docs/_includes/summary.html +0 -22
- data/docs/_includes/ufo-ship-options.md +0 -12
- data/docs/_includes/uses.html +0 -19
- data/docs/_layouts/default.html +0 -13
- data/docs/_layouts/style.css +0 -6
- data/docs/_reference/ufo-apps.md +0 -37
- data/docs/_reference/ufo-cancel.md +0 -24
- data/docs/_reference/ufo-completion.md +0 -46
- data/docs/_reference/ufo-completion_script.md +0 -27
- data/docs/_reference/ufo-current.md +0 -93
- data/docs/_reference/ufo-deploy.md +0 -76
- data/docs/_reference/ufo-destroy.md +0 -36
- data/docs/_reference/ufo-docker-base.md +0 -71
- data/docs/_reference/ufo-docker-build.md +0 -91
- data/docs/_reference/ufo-docker-clean.md +0 -44
- data/docs/_reference/ufo-docker-compile.md +0 -19
- data/docs/_reference/ufo-docker-help.md +0 -15
- data/docs/_reference/ufo-docker-name.md +0 -37
- data/docs/_reference/ufo-docker-push.md +0 -49
- data/docs/_reference/ufo-docker.md +0 -38
- data/docs/_reference/ufo-init.md +0 -125
- data/docs/_reference/ufo-logs.md +0 -40
- data/docs/_reference/ufo-network-help.md +0 -15
- data/docs/_reference/ufo-network-init.md +0 -39
- data/docs/_reference/ufo-network.md +0 -26
- data/docs/_reference/ufo-ps.md +0 -56
- data/docs/_reference/ufo-releases.md +0 -40
- data/docs/_reference/ufo-resources.md +0 -44
- data/docs/_reference/ufo-rollback.md +0 -61
- data/docs/_reference/ufo-scale.md +0 -50
- data/docs/_reference/ufo-ship.md +0 -129
- data/docs/_reference/ufo-ships.md +0 -68
- data/docs/_reference/ufo-status.md +0 -23
- data/docs/_reference/ufo-stop.md +0 -31
- data/docs/_reference/ufo-task.md +0 -56
- data/docs/_reference/ufo-tasks-build.md +0 -178
- data/docs/_reference/ufo-tasks-help.md +0 -15
- data/docs/_reference/ufo-tasks-register.md +0 -29
- data/docs/_reference/ufo-tasks.md +0 -35
- data/docs/_reference/ufo-upgrade-help.md +0 -15
- data/docs/_reference/ufo-upgrade-v2to3.md +0 -15
- data/docs/_reference/ufo-upgrade-v33to34.md +0 -15
- data/docs/_reference/ufo-upgrade-v3to4.md +0 -27
- data/docs/_reference/ufo-upgrade-v43to45.md +0 -15
- data/docs/_reference/ufo-upgrade.md +0 -29
- data/docs/_reference/ufo-version.md +0 -23
- data/docs/articles.md +0 -14
- data/docs/bin/web +0 -4
- data/docs/css/font-awesome/css/font-awesome.css +0 -1566
- data/docs/css/font-awesome/css/font-awesome.min.css +0 -4
- data/docs/css/font-awesome/fonts/FontAwesome.otf +0 -0
- data/docs/css/font-awesome/fonts/fontawesome-webfont.eot +0 -0
- data/docs/css/font-awesome/fonts/fontawesome-webfont.svg +0 -504
- data/docs/css/font-awesome/fonts/fontawesome-webfont.ttf +0 -0
- data/docs/css/font-awesome/fonts/fontawesome-webfont.woff +0 -0
- data/docs/docs.md +0 -29
- data/docs/img/docs/cloudformation-resources.png +0 -0
- data/docs/img/logos/boltops-logo-full.png +0 -0
- data/docs/img/logos/boltops-logo.png +0 -0
- data/docs/img/logos/ufo-logo-2.png +0 -0
- data/docs/img/logos/ufo-logo.png +0 -0
- data/docs/img/logos/ufo-site-header.png +0 -0
- data/docs/img/logos/ufo.jpg +0 -0
- data/docs/img/tutorials/ecs-console-task-definitions.png +0 -0
- data/docs/img/tutorials/ecs-console-ufo-ship.png +0 -0
- data/docs/img/tutorials/ecs-console-ufo-ships.png +0 -0
- data/docs/index.html +0 -10
- data/docs/js/bootstrap.js +0 -2114
- data/docs/js/bootstrap.min.js +0 -6
- data/docs/js/cbpAnimatedHeader.js +0 -44
- data/docs/js/cbpAnimatedHeader.min.js +0 -11
- data/docs/js/classie.js +0 -80
- data/docs/js/contact_me.js +0 -70
- data/docs/js/contact_me_static.js +0 -23
- data/docs/js/freelancer.js +0 -37
- data/docs/js/jqBootstrapValidation.js +0 -912
- data/docs/js/jquery-1.11.0.js +0 -4
- data/docs/js/jquery.easing.min.js +0 -44
- data/docs/js/nav.js +0 -53
- data/docs/quick-start.md +0 -133
- data/docs/reference.md +0 -29
- data/docs/style.css +0 -3
- data/docs/utils/ssl-doctor.rb +0 -89
- data/docs/utils/test-aws-api-access.rb +0 -11
- data/docs/utils/update-cert-chains.sh +0 -11
- data/lib/template/.env +0 -3
- data/lib/template/.secrets +0 -5
- data/lib/template/.ufo/iam_roles/execution_role.rb +0 -7
- data/lib/template/.ufo/iam_roles/task_role.rb +0 -21
- data/lib/template/.ufo/params.yml.tt +0 -27
- data/lib/template/.ufo/settings/cfn/default.yml.tt +0 -72
- data/lib/template/.ufo/settings/network/default.yml.tt +0 -26
- data/lib/template/.ufo/settings.yml.tt +0 -26
- data/lib/template/.ufo/task_definitions.rb.tt +0 -61
- data/lib/template/.ufo/templates/fargate.json.erb +0 -39
- data/lib/template/.ufo/templates/main.json.erb +0 -43
- data/lib/template/.ufo/variables/base.rb.tt +0 -19
- data/lib/template/.ufo/variables/development.rb +0 -8
- data/lib/template/.ufo/variables/production.rb +0 -7
- data/lib/template/Dockerfile +0 -15
- data/lib/template/bin/deploy.tt +0 -7
- data/lib/ufo/apps/cfn_map.rb +0 -70
- data/lib/ufo/apps/cluster.rb +0 -24
- data/lib/ufo/apps/service.rb +0 -56
- data/lib/ufo/apps.rb +0 -56
- data/lib/ufo/aws_service.rb +0 -36
- data/lib/ufo/base.rb +0 -35
- data/lib/ufo/cancel.rb +0 -23
- data/lib/ufo/current.rb +0 -104
- data/lib/ufo/default/settings.yml +0 -24
- data/lib/ufo/default/templates/main.json.erb +0 -39
- data/lib/ufo/destroy.rb +0 -41
- data/lib/ufo/docker/variables.rb +0 -26
- data/lib/ufo/dsl/helper.rb +0 -79
- data/lib/ufo/dsl/outputter.rb +0 -43
- data/lib/ufo/dsl/task_definition.rb +0 -108
- data/lib/ufo/dsl.rb +0 -96
- data/lib/ufo/help/apps.md +0 -12
- data/lib/ufo/help/balancer.md +0 -3
- data/lib/ufo/help/completions.md +0 -16
- data/lib/ufo/help/completions_script.md +0 -1
- data/lib/ufo/help/current.md +0 -65
- data/lib/ufo/help/deploy.md +0 -38
- data/lib/ufo/help/destroy.md +0 -9
- data/lib/ufo/help/docker/base.md +0 -49
- data/lib/ufo/help/docker/name.md +0 -16
- data/lib/ufo/help/docker.md +0 -6
- data/lib/ufo/help/init.md +0 -91
- data/lib/ufo/help/network/init.md +0 -13
- data/lib/ufo/help/ps.md +0 -27
- data/lib/ufo/help/releases.md +0 -16
- data/lib/ufo/help/resources.md +0 -20
- data/lib/ufo/help/rollback.md +0 -35
- data/lib/ufo/help/scale.md +0 -26
- data/lib/ufo/help/ship.md +0 -95
- data/lib/ufo/help/ships.md +0 -35
- data/lib/ufo/help/stop.md +0 -7
- data/lib/ufo/help/task.md +0 -27
- data/lib/ufo/help/tasks/build.md +0 -158
- data/lib/ufo/help/tasks/register.md +0 -14
- data/lib/ufo/help/tasks.md +0 -7
- data/lib/ufo/help/upgrade/v3to4.md +0 -3
- data/lib/ufo/help.rb +0 -9
- data/lib/ufo/init.rb +0 -119
- data/lib/ufo/network/fetch.rb +0 -48
- data/lib/ufo/network/helper.rb +0 -23
- data/lib/ufo/network/init.rb +0 -26
- data/lib/ufo/network.rb +0 -21
- data/lib/ufo/ps.rb +0 -129
- data/lib/ufo/scale.rb +0 -28
- data/lib/ufo/setting/profile.rb +0 -44
- data/lib/ufo/setting/security_groups.rb +0 -22
- data/lib/ufo/setting.rb +0 -75
- data/lib/ufo/settings.rb +0 -20
- data/lib/ufo/ship.rb +0 -103
- data/lib/ufo/stack/builder/conditions.rb +0 -23
- data/lib/ufo/stack/builder/parameters.rb +0 -45
- data/lib/ufo/stack/builder/resources/base.rb +0 -4
- data/lib/ufo/stack/builder/resources/dns.rb +0 -17
- data/lib/ufo/stack/builder/resources/elb.rb +0 -45
- data/lib/ufo/stack/builder/resources/listener.rb +0 -42
- data/lib/ufo/stack/builder/resources/listener_ssl.rb +0 -16
- data/lib/ufo/stack/builder/resources/roles/base.rb +0 -22
- data/lib/ufo/stack/builder/resources/roles/execution_role.rb +0 -4
- data/lib/ufo/stack/builder/resources/roles/task_role.rb +0 -4
- data/lib/ufo/stack/builder/resources/security_group/base.rb +0 -4
- data/lib/ufo/stack/builder/resources.rb +0 -20
- data/lib/ufo/stack/builder.rb +0 -26
- data/lib/ufo/stack/context.rb +0 -253
- data/lib/ufo/stack/helper.rb +0 -55
- data/lib/ufo/stack/template_body.rb +0 -13
- data/lib/ufo/stack.rb +0 -213
- data/lib/ufo/status.rb +0 -56
- data/lib/ufo/stop.rb +0 -49
- data/lib/ufo/task.rb +0 -225
- data/lib/ufo/tasks/builder.rb +0 -40
- data/lib/ufo/tasks/register.rb +0 -90
- data/lib/ufo/template_scope.rb +0 -57
- data/lib/ufo/util.rb +0 -69
- data/spec/lib/apps_spec.rb +0 -20
- data/spec/lib/builder_spec.rb +0 -23
- data/spec/lib/cli_spec.rb +0 -73
- data/spec/lib/completion_spec.rb +0 -18
- data/spec/lib/ps_spec.rb +0 -14
- data/spec/lib/register_spec.rb +0 -49
- data/spec/lib/setting_spec.rb +0 -18
- data/spec/lib/ship_spec.rb +0 -46
- data/spec/lib/stack/status_spec.rb +0 -76
- data/spec/lib/stop_spec.rb +0 -13
- data/spec/lib/task_spec.rb +0 -54
@@ -1,27 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Redirection Support
|
3
|
-
nav_order: 33
|
4
|
-
---
|
5
|
-
|
6
|
-
## Application Load Balancers
|
7
|
-
|
8
|
-
If you are using an Application Load Balancer you can configure redirection by editing the default actions of the regular listener that is set up by ufo. This assumes you have set up [SSL Support]({% link _docs/extras/ssl-support.md %}). Here's an example that redirects http to https with a 302 http status code:
|
9
|
-
|
10
|
-
```
|
11
|
-
Listener:
|
12
|
-
Port: 80
|
13
|
-
# ...
|
14
|
-
DefaultActions:
|
15
|
-
- Type: redirect
|
16
|
-
RedirectConfig:
|
17
|
-
Protocol: HTTPS
|
18
|
-
StatusCode: HTTP_302 # HTTP_301 and HTTP_302 are valid
|
19
|
-
Port: 443
|
20
|
-
```
|
21
|
-
|
22
|
-
|
23
|
-
## Network Load Balancers
|
24
|
-
|
25
|
-
Network Load Balancers work at layer 4, so they do not support redirection. Instead you need to handle redirection within your app.
|
26
|
-
|
27
|
-
{% include prev_next.md %}
|
@@ -1,27 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Route53 Support
|
3
|
-
nav_order: 32
|
4
|
-
---
|
5
|
-
|
6
|
-
Ufo can create a "pretty" route53 record and set it's value to the created ELB DNS name. This is done by configuring the `.ufo/settings/cfn/default.yml` file. Example:
|
7
|
-
|
8
|
-
```yaml
|
9
|
-
Dns:
|
10
|
-
Name: "{stack_name}.mydomain.com."
|
11
|
-
HostedZoneName: mydomain.com. # dont forget the trailing period
|
12
|
-
```
|
13
|
-
|
14
|
-
The `{stack_name}` variable gets substituted with the CloudFormation stack name launched by ufo. So for example:
|
15
|
-
|
16
|
-
ufo ship demo-web
|
17
|
-
|
18
|
-
Results in:
|
19
|
-
|
20
|
-
"{stack_name}.mydomain.com." => "development-demo-web.mydomain.com."
|
21
|
-
|
22
|
-
**IMPORTANT**: The route53 host zone must already exist. You can create route53 hosted zone with the cli like so:
|
23
|
-
|
24
|
-
aws route53 create-hosted-zone --name mydomain.com --caller-reference $(date +%s)
|
25
|
-
aws route53 list-hosted-zones
|
26
|
-
|
27
|
-
{% include prev_next.md %}
|
@@ -1,36 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Security Groups
|
3
|
-
nav_order: 29
|
4
|
-
---
|
5
|
-
|
6
|
-
Ufo creates and manages two security groups. One for the ELB and one for the ECS tasks.
|
7
|
-
|
8
|
-
Some consideration for these security groups:
|
9
|
-
|
10
|
-
* Network load balancers do not support security groups. So an ELB security group is only created if the load balancer is an Application load balancer.
|
11
|
-
* The ECS security group for tasks currently always gets created, but is only used if network_mode is awsvpc. This is because in bridge network mode the EC2 container instance’s Ethernet card and its security group is used. The EC2 containers group security group is outside the control of ufo. You’ll need to configure the security group appropriately yourself. Ufo will only assign the ECS security group when awsvpc node mode is used and ufo has control of the security group.
|
12
|
-
|
13
|
-
## EC2 Instance Security Group Help
|
14
|
-
|
15
|
-
If you are seeing that the Targets in the ELB Target Group are reporting unhealthy, it is usually a security group issue. You might see this output with `ufo ps`:
|
16
|
-
|
17
|
-
$ ufo ps --no-summary
|
18
|
-
+----------+------+--------------+----------------+---------+-------------------------+
|
19
|
-
| Id | Name | Release | Started | Status | Notes |
|
20
|
-
+----------+------+--------------+----------------+---------+-------------------------+
|
21
|
-
| 070a9c0a | web | demo-web:169 | 6 minutes ago | STOPPED | Failed ELB health check |
|
22
|
-
| d02728ba | web | demo-web:169 | 3 minutes ago | STOPPED | Failed ELB health check |
|
23
|
-
| 8dcf81ae | web | demo-web:169 | 13 seconds ago | RUNNING | |
|
24
|
-
+----------+------+--------------+----------------+---------+-------------------------+
|
25
|
-
There are targets in the target group reporting unhealthy. This can cause containers to cycle. Here's the error:
|
26
|
-
(service development-demo-web-Ecs-13D2BFA4ULNC9) (instance i-0812a3bcd94babf12) (port 32779) is unhealthy in (target-group arn:aws:elasticloadbalancing:us-east-1:111111111111:targetgroup/devel-Targe-1MJR8V6VOWBGI/3f44f85710fe0297) due to (reason Request timed out)
|
27
|
-
Check out the ECS console events tab for more info.
|
28
|
-
$
|
29
|
-
|
30
|
-
If you are using network mode bridge, then you'll need to need to configure the container instance's security group to allow traffic to the Docker ephemeral port range. For details on the Docker ephemeral port range on AWS, you search for "ephemeral" on the [ECS Port Mapping Docs](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_PortMapping.html).
|
31
|
-
|
32
|
-
In general, ports below 32768 are outside of the ephemeral port range. So an easy way to configure the container instance's security group is to whitelist ports 32768 to 65535 to your VPC's CIDR block. An example of a CIDR block range could be `10.0.0.0/16`. The CIDR block is being suggested because the Application load balancer and security group created by ufo can change if you change the load balancer settings.
|
33
|
-
|
34
|
-
If you are using a network load balancer and are running bridge network mode, then you need to whitelist ports 32768 to 65535 to `0.0.0.0/0`. This is because network load balancers operate at layer 4 of the OSI model and cannot be assigned security groups, so they use the security group of the instance. If you feel this is too loose of permissions, you can use awsvpc mode. There are some considerations for awsvpc mode though which is discussed next.
|
35
|
-
|
36
|
-
{% include prev_next.md %}
|
@@ -1,20 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: SSL Support
|
3
|
-
nav_order: 31
|
4
|
-
---
|
5
|
-
|
6
|
-
You can configure SSL support by uncomment the `listener_ssl` option in `.ufo/settings/cfn/default.yml`. Here's an example:
|
7
|
-
|
8
|
-
```
|
9
|
-
ListenerSsl:
|
10
|
-
Port: 443
|
11
|
-
Certificates:
|
12
|
-
- CertificateArn: arn:aws:acm:us-east-1:111111111111:certificate/11111111-2222-3333-4444-555555555555
|
13
|
-
```
|
14
|
-
|
15
|
-
For the certificate arn, you will need to create a certificate with AWS ACM. To do so, you can follow these instructions: [Request a Public Certificate
|
16
|
-
](https://docs.aws.amazon.com/acm/latest/userguide/gs-acm-request-public.html)
|
17
|
-
|
18
|
-
The protocol will be either HTTP or HTTPS for Application Load Balancers and TCP or TLS for Network Load Balancers. Ufo will infer the right value, so you usually don't have to configure the protocol manually. You can configure it if required though.
|
19
|
-
|
20
|
-
{% include prev_next.md %}
|
data/docs/_docs/faq.md
DELETED
@@ -1,100 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: FAQ
|
3
|
-
nav_order: 50
|
4
|
-
---
|
5
|
-
|
6
|
-
**Q: Is AWS ECS Fargate supported?**
|
7
|
-
|
8
|
-
Yes, Fargate is supported. To use ufo with Fargate, you will need to adjust the template in `.ufo/templates` to a structure supported by Fargate. There are 2 key items to adjust:
|
9
|
-
|
10
|
-
1. The task definition JSON. Notably, the JSON structure has the `requiresCompatibilities`, `networkMode`, and `executionRoleArn` attributes. The `cpu` and `memory` attributes also move outside of the `containerDefinitions` level to the top-level attributes. For details on how to adjust the task definition refer to [Task Definitions]({% link _docs/tutorial-ufo-tasks-build.md %}).
|
11
|
-
2. The params that get sent to the `run_task` API methods. For details on how to adjust the params refer to [Params]({% link _docs/ufo-task-params.md %})
|
12
|
-
|
13
|
-
If it's a brand new project, you can use `ufo init` with the `--launch-type fargate` option and it will generate a starter task definition JSON file that has the right Fargate structure. More info is available at [ufo init reference](/reference/ufo-init/#fargate-support).
|
14
|
-
|
15
|
-
A quick and easy way to test fargate is to follow the [Quick Start: Fargate Docs]({% link quick-start.md %}) which provides a demo example.
|
16
|
-
|
17
|
-
**Q: Can I tell ufo to use specific docker build options?**
|
18
|
-
|
19
|
-
Yes, you can do this with the environment variable `UFO_DOCKER_BUILD_OPTIONS`. Example:
|
20
|
-
|
21
|
-
```
|
22
|
-
$ UFO_DOCKER_BUILD_OPTIONS="--build-arg RAILS_ENV=production" ufo docker build
|
23
|
-
Building docker image with:
|
24
|
-
docker build --build-arg RAILS_ENV=production -t tongueroo/demo-ufo:ufo-2018-05-19T11-52-16-6714713 -f Dockerfile .
|
25
|
-
...
|
26
|
-
Docker image tongueroo/demo-ufo:ufo-2018-05-19T11-52-16-6714713 built. Took 2s.
|
27
|
-
```
|
28
|
-
|
29
|
-
---
|
30
|
-
|
31
|
-
**Q: Can you tell ufo to use a custom user-defined Docker tag name?**
|
32
|
-
|
33
|
-
In short, no. There's some image cleanup logic that relies on the specific naming convention. However, you can re-tag the build docker image with another tag after ufo is done building the image. The key is using the `ufo docker name` command to get the last docker image name that was built by ufo. Example:
|
34
|
-
|
35
|
-
```
|
36
|
-
$ ufo docker build
|
37
|
-
$ ufo docker name
|
38
|
-
tongueroo/demo-ufo:ufo-2018-05-19T11-41-06-6714713
|
39
|
-
$ docker tag $(ufo docker name) hi:mytag
|
40
|
-
$ docker images | grep hi
|
41
|
-
hi mytag 5b01e38bd060 3 minutes ago 955MB
|
42
|
-
tongueroo/demo-ufo ufo-2018-05-19T11-41-06-6714713 5b01e38bd060 3 minutes ago 955MB
|
43
|
-
$ docker push hi:mytag
|
44
|
-
```
|
45
|
-
|
46
|
-
---
|
47
|
-
|
48
|
-
**Q: What's the difference between ufo vs ecs-deploy?**
|
49
|
-
|
50
|
-
Some differences:
|
51
|
-
|
52
|
-
* ecs-deploy is implemented in bash
|
53
|
-
* ufo is implemented in ruby
|
54
|
-
* ecs-deploy is a simpler, which could work better for you. It’s nice that it’s one bash script.
|
55
|
-
|
56
|
-
ufo does 3 things:
|
57
|
-
|
58
|
-
1. Builds and pushes the Docker image
|
59
|
-
2. Builds and registers the task definition with ECS
|
60
|
-
3. Deploys by either creating or updating the ECS service
|
61
|
-
|
62
|
-
Ecs-deploy does step 2 and 3 but not step 1. For step 3, doesn’t look like ecs-deploy creates a service if it doesn’t exist. It’s more designed to update existing an ECS service.
|
63
|
-
|
64
|
-
The main difference is that ecs-deploy downloads current ECS task definition and replaces the image attribute. ufo regenerates the task definition from code each deploy. If you’re making adjustments to the task definition with the ECS console as your flow, the ecs-deploy makes more sense. If you want to keep your task definition codified than ufo makes more sense.
|
65
|
-
|
66
|
-
Some more differences:
|
67
|
-
|
68
|
-
* ufo creates the CloudWatch log group if doesn’t exist. Small thing but it’s easy to forget.
|
69
|
-
* ufo has a concept of variables that get layered. This is how it handles multi environments with very similar task definitions with just a few differences.
|
70
|
-
|
71
|
-
Generally, ufo does more in scope so we’re sort of comparing apples to oranges here. Hope that helps.
|
72
|
-
|
73
|
-
---
|
74
|
-
|
75
|
-
**Q: Is it somehow possible to change the templates for the files, that the ufo init-command generates? Most of my services follow the same overall structure, which means I'll have to perform the same changes every time I initialize a new UFO setup.**
|
76
|
-
|
77
|
-
Yes, this is achieved with the `--template` and `--template-mode` options when calling the `ufo init` command. The documentation for it is in the [ufo init reference docs](http://ufoships.com/reference/ufo-init/).
|
78
|
-
|
79
|
-
---
|
80
|
-
|
81
|
-
**Q: How can I use syslog instead of awslogs for logging?**
|
82
|
-
|
83
|
-
Open up `.ufo/templates/main.json.erb` - this gets created as part of the [ufo init](http://ufoships.com/reference/ufo-init/) command. Then you can adjust the ecs template definition to something like this:
|
84
|
-
|
85
|
-
```json
|
86
|
-
"logConfiguration": {
|
87
|
-
"logDriver": "syslog"
|
88
|
-
},
|
89
|
-
```
|
90
|
-
|
91
|
-
Here's the specific aws docs section [Specifying a Log Configuration in your Task Definition](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/using_awslogs.html#specify-log-config)
|
92
|
-
|
93
|
-
Also, you might have to enable the log driver by adding the ECS_AVAILABLE_LOGGING_DRIVERS variable to your `/etc/ecs/ecs.config`. Relevant docs:
|
94
|
-
|
95
|
-
* [Using AWS Logs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/using_awslogs.html#enable_awslogs)
|
96
|
-
* [ECS Agent Install](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-agent-install.html)
|
97
|
-
|
98
|
-
Hope that helps.
|
99
|
-
|
100
|
-
{% include prev_next.md %}
|
data/docs/_docs/fargate.md
DELETED
data/docs/_docs/helpers.md
DELETED
@@ -1,24 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Helpers
|
3
|
-
nav_order: 19
|
4
|
-
---
|
5
|
-
|
6
|
-
The `task_definitions.rb` file has access to helper methods. These helper methods provide useful contextual information about the project.
|
7
|
-
|
8
|
-
For example, one of the helper methods provides the exposed port in the Dockerfile of the project. This is useful if someone changes the exported port in the Dockerfile, he will likely forget also to update the ufo variable. You can reference the port via the helper to prevent this from happening. Here is a list of the helpers:
|
9
|
-
|
10
|
-
Helper | Description
|
11
|
-
------------- | -------------
|
12
|
-
full\_image\_name | The full docker image name that ufo builds. The "base" portion of the docker image name is defined in `settings.yml`. For example, the base portion is `tongueroo/demo-ufo` and the full image name is `tongueroo/demo-ufo:ufo-[timestamp]-[sha]`. The base name does not include the generated Docker tag, which contains a timestamp and git sha of the project.
|
13
|
-
dockerfile\_port | Exposed port extracted from the Dockerfile of the project.
|
14
|
-
env_vars(text) | This method takes a block of text that contains the env values in `key=value` format and converts that block of text to the proper task definition JSON format.
|
15
|
-
env_file(path) | This method takes a `.env` file which contains a simple key-value list of environment variables and converts the list to the proper task definition JSON format.
|
16
|
-
secrets_vars(text) | This method takes a block of text that contains the secrets values in `key=value` format and converts that block of text to the proper task definition JSON format.
|
17
|
-
secrets_file(path) | This method takes a `.secrets` file which contains a simple key-value list of environment variables and converts the list to the proper task definition JSON format.
|
18
|
-
task_definition_name | The name of the task_definition. So if the code looks like this `task_definition "demo-web" do`, the task_definition_name is "demo-web".
|
19
|
-
|
20
|
-
To call the helper in task_definitions.rb you must add `helper.` in front. So `full_image_name` is called via `helper.full_image_name`.
|
21
|
-
|
22
|
-
The 2 classes which provide these special helper methods are in [ufo/dsl.rb](https://github.com/tongueroo/ufo/blob/master/lib/ufo/dsl.rb) and [ufo/dsl/helper.rb](https://github.com/tongueroo/ufo/blob/master/lib/ufo/dsl/helper.rb). Refer to these classes for the full list of the helper methods.
|
23
|
-
|
24
|
-
{% include prev_next.md %}
|
data/docs/_docs/iam-roles.md
DELETED
@@ -1,112 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Task Definition IAM Roles
|
3
|
-
nav_order: 21
|
4
|
-
---
|
5
|
-
|
6
|
-
## What are ECS IAM Roles?
|
7
|
-
|
8
|
-
For ECS Task Definitions, you can assign it 2 IAM roles: 1) taskRoleArn and 2) executionRoleArn. It's usually defined in the JSON structure like so:
|
9
|
-
|
10
|
-
```json
|
11
|
-
{
|
12
|
-
"family": "..",
|
13
|
-
"taskRoleArn": "...",
|
14
|
-
"executionRoleArn": "...",
|
15
|
-
"containerDefinitions": [
|
16
|
-
...
|
17
|
-
]
|
18
|
-
}
|
19
|
-
```
|
20
|
-
|
21
|
-
Here's a table that explains the difference between the 2 IAM roles.
|
22
|
-
|
23
|
-
Name | Purpose
|
24
|
-
--- | ---
|
25
|
-
taskRoleArn | This is the role that the ECS task itself uses. So this is what IAM permissions your application has access to. Think about it as the "container role".
|
26
|
-
executionRoleArn | This is the role that the EC2 instance host uses. This allows the EC2 instance to pull from the ECR registry. Think about it as the "host role".
|
27
|
-
|
28
|
-
## How to Assign IAM Roles with UFO
|
29
|
-
|
30
|
-
You can assign an IAM role to the ECS Task definition in ways:
|
31
|
-
|
32
|
-
1. IAM Role with Code (UFO Managed)
|
33
|
-
2. Precreated IAM Role
|
34
|
-
|
35
|
-
## IAM Role with Code (UFO Managed)
|
36
|
-
|
37
|
-
UFO can automatically create the IAM and assign it to the task definition. You create these files so UFO will know to create and manage the IAM roles.
|
38
|
-
|
39
|
-
.ufo/iam_roles/execution_role.rb
|
40
|
-
.ufo/iam_roles/task_role.rb
|
41
|
-
|
42
|
-
### Example 1
|
43
|
-
|
44
|
-
You then use a DSL to create the IAM roles. Here are examples:
|
45
|
-
|
46
|
-
.ufo/iam_roles/execution_role.rb
|
47
|
-
|
48
|
-
```ruby
|
49
|
-
managed_iam_policy("AmazonSSMReadOnlyAccess")
|
50
|
-
managed_iam_policy("SecretsManagerReadWrite")
|
51
|
-
managed_iam_policy("service-role/AmazonECSTaskExecutionRolePolicy")
|
52
|
-
```
|
53
|
-
|
54
|
-
.ufo/iam_roles/task_role.rb
|
55
|
-
|
56
|
-
```ruby
|
57
|
-
iam_policy("AmazonS3ReadOnlyAccess",
|
58
|
-
Action: [
|
59
|
-
"s3:Get*",
|
60
|
-
"s3:List*"
|
61
|
-
],
|
62
|
-
Effect: "Allow",
|
63
|
-
Resource: "*"
|
64
|
-
)
|
65
|
-
iam_policy("CloudwatchWrite",
|
66
|
-
Action: [
|
67
|
-
"cloudwatch:PutMetricData",
|
68
|
-
],
|
69
|
-
Effect: "Allow",
|
70
|
-
Resource: "*"
|
71
|
-
)
|
72
|
-
```
|
73
|
-
|
74
|
-
### Example 2
|
75
|
-
|
76
|
-
You can use the `managed_iam_policy` and `iam_policy` together. You can also group multiple statements in the `iam_policy` declaration.
|
77
|
-
|
78
|
-
.ufo/iam_roles/task_role.rb
|
79
|
-
|
80
|
-
```ruby
|
81
|
-
managed_iam_policy("AmazonSSMManagedInstanceCore")
|
82
|
-
|
83
|
-
iam_policy("custom-policy", [
|
84
|
-
{
|
85
|
-
Action: "ecs:UpdateContainerInstancesState",
|
86
|
-
Resource: "*",
|
87
|
-
Effect: "Allow"
|
88
|
-
},
|
89
|
-
{
|
90
|
-
Action: "sns:Publish",
|
91
|
-
Resource: "*",
|
92
|
-
Effect: "Allow"
|
93
|
-
}
|
94
|
-
])
|
95
|
-
```
|
96
|
-
|
97
|
-
## Pre-Created IAM Role
|
98
|
-
|
99
|
-
You can also assign the task definition `executionRoleArn` with pre-created IAM roles. It looks something like this in the `.ufo/templates/main.json.erb` file:
|
100
|
-
|
101
|
-
```json
|
102
|
-
{
|
103
|
-
"family": "<%= @family %>",
|
104
|
-
"taskRoleArn": "arn:aws:iam::112233445566:role/pre-created-iam-role",
|
105
|
-
"executionRoleArn": "arn:aws:iam::112233445566:role/pre-created-iam-role",
|
106
|
-
"containerDefinitions": [
|
107
|
-
...
|
108
|
-
]
|
109
|
-
}
|
110
|
-
```
|
111
|
-
|
112
|
-
{% include prev_next.md %}
|
data/docs/_docs/install.md
DELETED
@@ -1,25 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Installation
|
3
|
-
nav_order: 3
|
4
|
-
---
|
5
|
-
|
6
|
-
## Install with RubyGems
|
7
|
-
|
8
|
-
You can install ufo with RubyGems:
|
9
|
-
|
10
|
-
```sh
|
11
|
-
gem install ufo
|
12
|
-
```
|
13
|
-
|
14
|
-
Or you can add ufo to your Gemfile in your project if you are working with a ruby project. It is not required for your project to be a ruby project to use ufo.
|
15
|
-
|
16
|
-
{% highlight ruby %}
|
17
|
-
gem "ufo"
|
18
|
-
{% endhighlight %}
|
19
|
-
|
20
|
-
## Dependencies
|
21
|
-
|
22
|
-
* Docker: You will need a working version of [Docker](https://docs.docker.com/engine/installation/) installed as ufo shells out and calls the `docker` command.
|
23
|
-
* AWS: Set up your AWS credentials at `~/.aws/credentials` and `~/.aws/config`. This is the [AWS standard way of setting up credentials](https://aws.amazon.com/blogs/security/a-new-and-standardized-way-to-manage-credentials-in-the-aws-sdks/).
|
24
|
-
|
25
|
-
{% include prev_next.md %}
|
@@ -1,24 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Auto Completion
|
3
|
-
nav_order: 49
|
4
|
-
---
|
5
|
-
|
6
|
-
Ufo supports bash auto-completion. To set it up add the following to your `~/.profile` or `.bashrc`:
|
7
|
-
|
8
|
-
eval $(ufo completion_script)
|
9
|
-
|
10
|
-
Remember to restart your shell or source your profile file.
|
11
|
-
|
12
|
-
Auto Completion examples:
|
13
|
-
|
14
|
-
ufo [TAB]
|
15
|
-
ufo ship [TAB]
|
16
|
-
ufo ship demo-web [TAB]
|
17
|
-
ufo ship demo-web --[TAB]
|
18
|
-
ufo ship --[TAB]
|
19
|
-
ufo docker [TAB]
|
20
|
-
ufo docker build [TAB]
|
21
|
-
ufo tasks [TAB]
|
22
|
-
ufo tasks build [TAB]
|
23
|
-
|
24
|
-
{% include prev_next.md %}
|
@@ -1,14 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Automated Clean Up
|
3
|
-
nav_order: 48
|
4
|
-
---
|
5
|
-
|
6
|
-
Ufo can be configured to automatically clean old images from the ECR registry after the deploy completes by configuring your [settings.yml]({% link _docs/settings.md %}) file like so:
|
7
|
-
|
8
|
-
```yaml
|
9
|
-
ecr_keep: 30
|
10
|
-
```
|
11
|
-
|
12
|
-
Automated Docker images clean up only works if you are using ECR registry.
|
13
|
-
|
14
|
-
{% include prev_next.md %}
|
@@ -1,35 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Customize CloudFormation
|
3
|
-
nav_order: 43
|
4
|
-
---
|
5
|
-
|
6
|
-
Under the hood, ufo creates most of the required resources with a CloudFormation stack. This includes the ELB, Target Group, Listener, Security Groups, ECS Service, and Route 53 records. You might need to customize these resources. Here are the ways to customize the resources that ufo creates.
|
7
|
-
|
8
|
-
1. Settings - This is done with the `.ufo/settings/cfn/default.yml` file. This is the main and recommended way to customize.
|
9
|
-
2. Override cfn template - You can specify your own template to use. You save this template at `.ufo/settings/cfn/stack.yml`. Use this approach as a last resort only when necessary.
|
10
|
-
|
11
|
-
## Settings
|
12
|
-
|
13
|
-
The recommended approach to customize the CloudFormation resources is by adding properties to `.ufo/settings/cfn/default.yml`.
|
14
|
-
|
15
|
-
{% include cfn-customize.md %}
|
16
|
-
|
17
|
-
## Override Cfn Template
|
18
|
-
|
19
|
-
You can override the source template that ufo uses by creating your own and saving it at `.ufo/settings/cfn/stack.yml` in your project. It is recommended that you copy the source code and work from there [cfn/stack.yml](https://github.com/tongueroo/ufo/blob/master/lib/cfn/stack.yml). Use this approach as a last resort only when absolutely necessary as it'll likely break with a future version of ufo.
|
20
|
-
|
21
|
-
## CloudFormation Stack Name
|
22
|
-
|
23
|
-
The CloudFormation stack name is based on the service name, UFO_ENV and UFO_ENV_EXTRA. A few examples help demonstrate:
|
24
|
-
|
25
|
-
Command | Stack Name
|
26
|
-
--- | ---
|
27
|
-
ufo ship demo-web | demo-web-development
|
28
|
-
ufo ship demo-web -\-cluster dev | demo-web-development
|
29
|
-
UFO_ENV_EXTRA=2 ufo ship demo-web -\-cluster dev | demo-web-development-2
|
30
|
-
|
31
|
-
## CloudFormation Stack Source Code
|
32
|
-
|
33
|
-
The CloudFormation stack is currently generated from a template. The source code for this template is located at [cfn/stack.yml](https://github.com/tongueroo/ufo/blob/master/lib/cfn/stack.yml). This implementation might change in the future.
|
34
|
-
|
35
|
-
{% include prev_next.md %}
|
@@ -1,25 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Database Migrations
|
3
|
-
nav_order: 47
|
4
|
-
---
|
5
|
-
|
6
|
-
A common task is to run database migrations with newer code before deploying the code. This is easily achieved with the `ufo task` command. Here's an example:
|
7
|
-
|
8
|
-
ufo task demo-web -c bundle exec rake db:migrate
|
9
|
-
|
10
|
-
It is nice to wrap the commands in a wrapper script in case you have to do things like to load the environment.
|
11
|
-
|
12
|
-
ufo task demo-web -c bin/migrate
|
13
|
-
|
14
|
-
The `bin/migrate` script can look like this:
|
15
|
-
|
16
|
-
#!/bin/bash
|
17
|
-
bundle exec rake db:migrate
|
18
|
-
|
19
|
-
The `ufo task` command is generalized so you can run any one-off task. It is not just limited to running migrations. The `ufo task` command performs the following:
|
20
|
-
|
21
|
-
1. Builds the docker image and pushes it to a registry
|
22
|
-
2. Registers the ECS Task definition
|
23
|
-
3. Runs a one-off ECS Task
|
24
|
-
|
25
|
-
{% include prev_next.md %}
|
@@ -1,30 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Run in Pieces
|
3
|
-
nav_order: 45
|
4
|
-
---
|
5
|
-
|
6
|
-
The `ufo ship` command goes through a few stages:
|
7
|
-
|
8
|
-
1. building the docker image
|
9
|
-
2. registering the task defiintions
|
10
|
-
2. updating the ECS service.
|
11
|
-
|
12
|
-
The CLI exposes many of these steps as separate commands. Here is now you would be able to run each of the steps in pieces.
|
13
|
-
|
14
|
-
Build the docker image first.
|
15
|
-
|
16
|
-
ufo docker build
|
17
|
-
ufo docker push # pushes last built image to a registry
|
18
|
-
|
19
|
-
Build the task definitions.
|
20
|
-
|
21
|
-
ufo tasks build # generates task definition json files to .ufo/output
|
22
|
-
ufo tasks register # registers all genreated task definitions .ufo/output to ECS
|
23
|
-
|
24
|
-
Update the service with the task definitions in `.ufo/output` untouched.
|
25
|
-
|
26
|
-
ufo deploy demo-web
|
27
|
-
|
28
|
-
Note if you use the `ufo deploy` you should ensure that you have already pushed the docker image to your docker registry. Or else the task will not be able to spin up because the docker image does not exist. This is one of the reasons it is recommended that you use `ufo ship`.
|
29
|
-
|
30
|
-
{% include prev_next.md %}
|
@@ -1,25 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Run Single Task
|
3
|
-
nav_order: 46
|
4
|
-
---
|
5
|
-
|
6
|
-
Sometimes you do not want to run a long running `service` but a one time task. Running Rails migrations are an example of a one off task. Here is an example of how you would run a one time task.
|
7
|
-
|
8
|
-
ufo task demo-web -c bundle exec rake db:migrate
|
9
|
-
|
10
|
-
At the end of the output you should see you the task ARN:
|
11
|
-
|
12
|
-
|
13
|
-
$ ufo task demo-web -c bundle exec rake db:migrate
|
14
|
-
...
|
15
|
-
Running task_definition: demo-web
|
16
|
-
Task ARN: arn:aws:ecs:us-west-2:994926937775:task/a0e4229d-3d39-4b26-9151-6ab6869b84d4
|
17
|
-
$
|
18
|
-
|
19
|
-
You can describe that task for more details:
|
20
|
-
|
21
|
-
aws ecs describe-tasks --tasks arn:aws:ecs:us-west-2:994926937775:task/a0e4229d-3d39-4b26-9151-6ab6869b84d4
|
22
|
-
|
23
|
-
You can check out the [ufo task](http://ufoships.com/reference/ufo-task/) reference for more details.
|
24
|
-
|
25
|
-
{% include prev_next.md %}
|
@@ -1,29 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Stuck CloudFormation
|
3
|
-
nav_order: 44
|
4
|
-
---
|
5
|
-
|
6
|
-
The CloudFormation stack update or creation can get stuck in a `*_IN_PROGRESS` state for a very long time, like more than an hour. This happens when you deploy an ECS service that fails to stabilize. Usually, this is an error with the Docker container failing to start up successfully.
|
7
|
-
There can be many reasons for this, here are some examples:
|
8
|
-
|
9
|
-
* Bug in the startup script in the Dockerfile.
|
10
|
-
* There are no container instances available to place the docker ECS task.
|
11
|
-
* You have a rails app and it is failing to connect to the database upon startup, maybe due to a security group setting.
|
12
|
-
|
13
|
-
To resolve this, you can:
|
14
|
-
|
15
|
-
1. cancel the current deploy
|
16
|
-
2. fix the underlying issue
|
17
|
-
3. deploy again
|
18
|
-
|
19
|
-
## Canceling Deployment
|
20
|
-
|
21
|
-
If an ECS deployment does not finish within 10 minutes because the ECS service is not stabilizing, it is usually due one of the reasons above. In these cases, it is safe to cancel and try again.
|
22
|
-
|
23
|
-
To cancel a current deploy, run:
|
24
|
-
|
25
|
-
ufo cancel
|
26
|
-
|
27
|
-
This is the same thing as canceling the stack update in the CloudFormation console.
|
28
|
-
|
29
|
-
{% include prev_next.md %}
|
@@ -1,21 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Why CloudFormation
|
3
|
-
nav_order: 42
|
4
|
-
---
|
5
|
-
|
6
|
-
Version 3 of ufo was a simpler implementation and did not make use of CloudFormation to create the ECS service. In version 4, ufo uses CloudFormation to create the ECS Service. This is because ufo became more powerful. Notably, support for Load Balancers was added. With this power, also came added complexity. So the complexity was push onto CloudFormation. Hence, ECS service is implemented as CloudFormation resource in version 4.
|
7
|
-
|
8
|
-
My gut was already telling me that with Load Balancer support, the "orchestration" or sequencing logic in ufo would become annoyingly complex and shifting it to CloudFormation would be worth it. Nevertheless, I took the time with quick experimental branch and added Load Balancer support using the aws-sdk directly without CloudFormation.
|
9
|
-
|
10
|
-
The pull request for that code is here [ufo/pull/42](https://github.com/tongueroo/ufo/pull/42). An additional tool was created for the non-CloudFormation approach called [balancer](https://github.com/tongueroo/balancer). Balancer is a standalone tool used to create load balancers consistently with "profile" files.
|
11
|
-
|
12
|
-
* [ufo/pull/42](https://github.com/tongueroo/ufo/pull/42) - PR for non-CloudFormation. Closed and not used.
|
13
|
-
* [ufo/pull/43](https://github.com/tongueroo/ufo/pull/43) - PR for CloudFormation. Merged and used.
|
14
|
-
|
15
|
-
The results of the exercise confirm my gut. Though the CloudFormation implementation requires more upfront investment, it ultimately pays off. For example, route53 DNS support was added to ufo easily and quickly. Sometimes the learning curve of CloudFormation can be a deterrent, so I hope that these thoughts help.
|
16
|
-
|
17
|
-
You can check the resources created with CloudFormation by clicking on the stack name of in the CloudFormation console.
|
18
|
-
|
19
|
-
<img src="/img/docs/cloudformation-resources.png" class="doc-photo" />
|
20
|
-
|
21
|
-
{% include prev_next.md %}
|
data/docs/_docs/next-steps.md
DELETED
@@ -1,16 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: Next Steps
|
3
|
-
nav_order: 52
|
4
|
-
---
|
5
|
-
|
6
|
-
This concludes the tutorial guide for ufo. Hopefully you are now more comfortable with ufo's basic usage, concepts, and have a feel for the workflow.
|
7
|
-
|
8
|
-
From here, there are a few resources that can help you continue along:
|
9
|
-
|
10
|
-
* Check out the [ufo](https://github.com/tongueroo/ufo) repo on GitHub
|
11
|
-
* Submit an issue
|
12
|
-
* Write a blog post describing how you are using ufo, or an interesting problem ufo has allowed you to solve
|
13
|
-
|
14
|
-
Everyone can contribute to make ufo better, including the documentation. These docs are of the same ufo repo in the [docs folder](https://github.com/tongueroo/ufo/tree/master/docs). Please fork the project and open a pull request! We love your pull requests. Contributions are encouraged and welcomed!
|
15
|
-
|
16
|
-
{% include prev_next.md %}
|