Skip to content

scaleway deploy container with registry and custom endpoint dns

License

Notifications You must be signed in to change notification settings

philibea/scaleway-containers-deploy

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

Scaleway logo

The simplest way to deploy your app in Scaleway


Scaleway GitHub Action

Scaleway Containers Github Action is a Github Action plugin allowing Scaleway users to integrate Containers within their CI nicely.

✅ Requirements

  • A Scaleway account. Sign up now if you don't have any account yet.

📖 Installation

  • Create an API key: how to generate your API token?

  • Setup a secret named SCW_SECRET_KEY & SCW_ACCESS_KEY within your repository Secrets section and set its value with output of the previous step.

  • Setup a Registry Actually only Scaleway Registry is available.

  • Setup a Containers Namespace SCW_CONTAINER_NAMESPACE_ID within your repository Secrets section and set its value with your Scaleway account namespace. This Namespace is used inside the same Region of your registry.

You can can setup this namespace with our cli scw containers namespace create command.

  • (optional) Setup a SCW_DNS_ZONE within your repository Secrets section and set its value with your Scaleway account DNS zone. How To add Custom Domains. In this automation process, we will use the DNS zone of your Scaleway account. Each zone will be based on the container name created and based on the tag of your Image. Your path registry is rg.fr-par.scw.cloud/test/images:latest, your container name tag will be latest and your DNS zone will be latest.${SCW_DNS_ZONE}.

🔌 Usage

scw_access_key, scw_secret_key & scw_containers_namespace_id will always be necessary

simple deploy

input name value
type deploy (default value )
scw_registry rg.fr-par.scw.cloud/test/images:latest
scw_region fr-par (default value)
scw_container_port 80 (default value )
scw_memory_limit 256 (default value )
scw_min_scale 1 (default value )
scw_max_scale 5 (default value )
scw_max_concurrency 5 (default value )
scw_cpu_limit 70 (default value )
scw_sandbox v1
on: [push]

jobs:
  deploy:
    runs-on: ubuntu-latest
    name: Deploy on Scaleway Containers
    steps:
      - name: Checkout
        uses: actions/checkout@v3
      - name: Scaleway Container Deploy action
        id: deploy
        uses:  philibea/[email protected]
        with:
          type: deploy
          scw_access_key:  ${{ secrets.ACCESS_KEY }}
          scw_secret_key: ${{ secrets.SECRET_KEY }}
          scw_containers_namespace_id: ${{ secrets.CONTAINERS_NAMESPACE_ID }}
          scw_registry: rg.fr-par.scw.cloud/test/testing:latest

simple teardown

input name value
type teardown
scw_registry rg.fr-par.scw.cloud/test/images:latest
on: [push]

jobs:
  deploy:
    runs-on: ubuntu-latest
    name: Teardown Containers
    steps:
      - name: Checkout
        uses: actions/checkout@v3
      - name: Scaleway Container Teardown action
        id: teardown
        uses:  philibea/[email protected]
        with:
          type: teardown
          scw_access_key:  ${{ secrets.ACCESS_KEY }}
          scw_secret_key: ${{ secrets.SECRET_KEY }}
          scw_containers_namespace_id: ${{ secrets.CONTAINERS_NAMESPACE_ID }}
          scw_registry: rg.fr-par.scw.cloud/test/testing:latest

deploy with environment variables and secrets

Note: The environment variables/secrets values can't contains commas nor equal signs.

input name value
type deploy (default value )
scw_registry rg.fr-par.scw.cloud/test/images:latest
scw_region fr-par (default value)
scw_container_port 80 (default value )
scw_memory_limit 256 (default value )
scw_environment_variables HELLO=WORLD,JOHN=DOE
scw_secrets HELLO=WORLD,JOHN=DOE
on: [push]

jobs:
  deploy:
    runs-on: ubuntu-latest
    name: Deploy on Scaleway Containers
    steps:
      - name: Checkout
        uses: actions/checkout@v3
      - name: Scaleway Container Deploy action
        id: deploy
        uses:  philibea/[email protected]
        with:
          type: deploy
          scw_access_key:  ${{ secrets.ACCESS_KEY }}
          scw_secret_key: ${{ secrets.SECRET_KEY }}
          scw_containers_namespace_id: ${{ secrets.CONTAINERS_NAMESPACE_ID }}
          scw_registry: rg.fr-par.scw.cloud/test/testing:latest
          scw_environment_variables: HELLO=WORLD,JOHN=DOE
          scw_secrets: ${{ secrets.SECRETS }}

deploy to another region using an external registry

input name value
type deploy (default value )
scw_registry registry.hub.docker.com/library/nginx:latest
scw_region nl-ams
scw_container_port 80 (default value )
scw_memory_limit 256 (default value )
on: [push]

jobs:
  deploy:
    runs-on: ubuntu-latest
    name: Deploy on Scaleway Containers
    steps:
      - name: Checkout
        uses: actions/checkout@v3
      - name: Scaleway Container Deploy action
        id: deploy
        uses:  philibea/[email protected]
        with:
          type: deploy
          scw_access_key:  ${{ secrets.ACCESS_KEY }}
          scw_secret_key: ${{ secrets.SECRET_KEY }}
          scw_containers_namespace_id: ${{ secrets.CONTAINERS_NAMESPACE_ID }}
          scw_registry: registry.hub.docker.com/library/nginx:latest
          scw_region: nl-ams

dns deploy

input name value
type deploy
scw_registry rg.fr-par.scw.cloud/test/images:latest
scw_dns containers.test.fr

Actually, prefix of your dns will use the default value: "name of you created container" This created containers will be based on the tag name of the registry.

on: [push]

jobs:
  deploy:
    runs-on: ubuntu-latest
    name: Deploy on Scaleway Containers
    steps:
      - name: Checkout
        uses: actions/checkout@v3
      - name: Scaleway Container Deploy action
        id: deploy
        uses:  philibea/[email protected]
        with:
          type: deploy
          scw_access_key:  ${{ secrets.ACCESS_KEY }}
          scw_secret_key: ${{ secrets.SECRET_KEY }}
          scw_containers_namespace_id: ${{ secrets.CONTAINERS_NAMESPACE_ID }}
          scw_registry: rg.fr-par.scw.cloud/test/testing:latest
          scw_dns: containers.test.fr

dns teardown

input name value
type teardown
scw_registry rg.fr-par.scw.cloud/test/images:latest
scw_dns containers.test.fr
scw_dns_prefix (optional) testing
on: [push]

jobs:
  deploy:
    runs-on: ubuntu-latest
    name: Teardown Containers
    steps:
      - name: Checkout
        uses: actions/checkout@v3
      - name: Scaleway Container Teardown action
        id: teardown
        uses:  philibea/[email protected]
        with:
          type: teardown
          scw_access_key:  ${{ secrets.ACCESS_KEY }}
          scw_secret_key: ${{ secrets.SECRET_KEY }}
          scw_containers_namespace_id: ${{ secrets.CONTAINERS_NAMESPACE_ID }}
          scw_registry: rg.fr-par.scw.cloud/test/testing:latest
          scw_dns: containers.test.fr

dns deploy on root zone

if you want to deploy a container on your zone, you will need to control a new boolean variable root_zone

🐳 Docker

If you want to use this flow outside of Github Actions, you can use the Docker Image.

docker run -it --rm \
  -e INPUT_SCW_ACCESS_KEY=${SCW_ACCESS_KEY} \
  -e INPUT_SCW_SECRET_KEY=${SCW_SECRET_KEY} \
  -e INPUT_SCW_CONTAINERS_NAMESPACE_ID=${SCW_CONTAINERS_NAMESPACE_ID} \
  -e INPUT_SCW_REGISTRY=rg.fr-par.scw.cloud/test/testing:latest \
  -e INPUT_SCW_DNS=containers.test.fr \
  -e INPUT_TYPE=deploy \
  phiphi/scaleway-containers-deploy:latest

Gitlab

If you want to use this flow outside of Github Actions, you can use the Docker Image inside you gitlab-ci configuration. You can check an exemple in this directory here