-[Terraform] [Backends] [v0.9] How to manage tfstate files -Migrate the infrastructure of group companies to ECS/Fargate and look back -[AWS] [Terraform] [Fargate] Put container under ALB with ECS
$ yamllint .circleci/config.yml
$ circleci orb validate .circleci/config.yml
$ circleci local execute -c .circleci/config.yml --job build
$ circleci build --job rspec .circleci/config.yml
.circleci/config.yml
:.circleci/config.yml
version: 2.1
orbs:
aws-ecr: circleci/[email protected]
aws-ecs: circleci/[email protected]
/// executors:Define the environment for step execution of the job///
executors:
default:
docker:
- image: circleci/ruby:2.7.1-node-browsers-legacy
environment:
BUNDLE_JOBS: 3
BUNDLE_RETRY: 3
BUNDLE_PATH: vendor/bundle
RAILS_ENV: test
DATABASE_HOST: '127.0.0.1'
DB_USERNAME: 'root'
DB_PASSWORD: 'XXXXXX'
- image: circleci/mysql:5.7
environment:
MYSQL_DATABASE: sample_dev
MYSQL_USER: 'root'
MYSQL_ROOT_PASSWORD: 'XXXXXX'
docker_build:
machine:
docker_layer_caching: true
/// commands:Define a series of steps to be executed in a job as a map///
commands:
bundle_install_rspec:
steps:
- run:
name: Which bundler?
command: bundle -v
///Speed ​​up jobs by restoring the job cache///
- restore_cache:
keys:
- cache-gem-{{ checksum "Gemfile.lock" }}
- cache-gem-
- run:
name: Bundle Install
command: bundle check || bundle install
- save_cache:
key: cache-gem-{{ checksum "Gemfile.lock" }}
paths:
- vendor/bundle
- run:
name: Database create
command: DISABLE_SPRING=true bin/rake db:create --trace
- run:
name: Database setup
command: DISABLE_SPRING=true bin/rake db:schema:load --trace
- run:
name: Run rspec
command: |
TZ=Asia/Tokyo \
bundle exec rspec --profile 10 \
--out test_results/rspec.xml \
--format progress \
$(circleci tests glob "spec/**/*_spec.rb" | circleci tests split --split-by=timings)
///Vue installation///
vue-installation:
steps:
- restore_cache:
keys:
- cache-yarn-{{ checksum "yarn.lock" }}
- cache-yarn-
- run:
name: Yarn Install
command: yarn install
- save_cache:
key: cache-yarn-{{ checksum "yarn.lock" }}
paths:
- node_modules
///jobs: execution process///
jobs:
rspec:
working_directory: ~/rspec
executor: default
steps:
- checkout
- bundle_install_rspec
- vue-installation
deploy_app:
working_directory: ~/app
executor: default
steps:
- setup_remote_docker
- checkout
///workflows: orchestration of all jobs///
workflows:
version: 2
build-and-deploy:
jobs:
- rspec
- deploy_app:
requires:
- rspec
- aws-ecr/build-and-push-image:
requires:
- deploy_app
account-url: AWS_ECR_ACCOUNT_URL
aws-access-key-id: AWS_ACCESS_KEY_ID
aws-secret-access-key: AWS_SECRET_ACCESS_KEY
region: AWS_DEFAULT_REGION
repo: "${AWS_RESOURCE_NAME_PREFIX}"
dockerfile: docker/dev/app/Dockerfile
tag: "${CIRCLE_SHA1}"
- aws-ecs/deploy-service-update:
requires:
- aws-ecr/build-and-push-image
aws-region: AWS_DEFAULT_REGION
family: "${AWS_RESOURCE_NAME_PREFIX}-service"
cluster-name: "${AWS_RESOURCE_NAME_PREFIX}-cluster"
container-image-name-updates: "container=${AWS_RESOURCE_NAME_PREFIX}-container,image-and-tag=${AWS_ECR_ACCOUNT_URL}/${AWS_RESOURCE_NAME_PREFIX}:${CIRCLE_SHA1}"
- aws-ecs/run-task:
requires:
- aws-ecs/deploy-service-update
cluster: "${AWS_RESOURCE_NAME_PREFIX}-cluster"
aws-region: AWS_DEFAULT_REGION
task-definition: "${AWS_RESOURCE_NAME_PREFIX}-task-definition"
count: 1
launch-type: FARGATE
awsvpc: true
subnet-ids: subnet-XXXXXX,subnet-XXXXXX
security-group-ids: sg-XXXXXX,sg-XXXXXX
overrides: "{\\\"containerOverrides\\\":[{\\\"name\\\": \\\"${AWS_RESOURCE_NAME_PREFIX}-container\\\",\\\"command\\\": [\\\"bundle\\\", \\\"exec\\\", \\\"rake\\\", \\\"db:migrate\\\", \\\"RAILS_ENV=test\\\"]}]}"
Recommended Posts