Create a workflow for staging and production instances
Click on Actions tab within the Github repo and then Press on New workflow
You can skip this (Choose a workflow template) and click the Setup a workflow yourself and start from scratch.
Setup workflow files
production.yml
# This is a basic workflow to help you get started with Actions
name: CD
# Controls when the action will run. Triggers the workflow on push or pull request
# events but only for the master branch
on:
push:
branches: [master]
pull_request:
branches: [master]
# A map of environment variables that are available to all jobs and steps in the workflow
env:
AWS_ENVIRONMENT_NAME: nest-production
AWS_DEFAULT_REGION: ap-northeast-1
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
build:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
- uses: actions/setup-node@v1
with:
node-version: '12.x'
registry-url: 'https://registry.npmjs.org'
- name: Install
run: |
node -v
yarn -v
yarn install
- name: Build
run: yarn build
- name: Deploy
uses: hmanzur/actions-aws-eb@v1.0.0
with:
command: 'deploy ${{ env.AWS_ENVIRONMENT_NAME }}'
env:
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_DEFAULT_REGION: ${{ env.AWS_DEFAULT_REGION }}
staging.yml
# This is a basic workflow to help you get started with Actions
name: CD
# Controls when the action will run. Triggers the workflow on push or pull request
# events but only for the master branch
on:
push:
branches: [staging]
pull_request:
branches: [staging]
# A map of environment variables that are available to all jobs and steps in the workflow
env:
AWS_ENVIRONMENT_NAME: nest-staging
AWS_DEFAULT_REGION: ap-northeast-1
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
build:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
- uses: actions/setup-node@v1
with:
node-version: '12.x'
registry-url: 'https://registry.npmjs.org'
- name: Install
run: |
node -v
yarn -v
yarn install
- name: Build
run: yarn build
- name: Deploy
uses: hmanzur/actions-aws-eb@v1.0.0
with:
command: 'deploy ${{ env.AWS_ENVIRONMENT_NAME }}'
env:
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_DEFAULT_REGION: ${{ env.AWS_DEFAULT_REGION }}
Replace AWS_ENVIRONMENT_NAME with your environment of the elastic beanstalk application.
Replace AWS_DEFAULT_REGION with the region where you created your elastic beanstalk application.
Add AWS secrets to Github
Push code to Github then Github Action will deploy your app to aws automatically