Docker Image

Build component for Docker images

Introduction

Docker Image Components are useful when you don't have your images already built (by a pipeline). Defining such a component will enable Bunnyshell to build your images for you to use in other components.

Docker Image components are not displayed in the main user interface. They can be defined and edited only with the bunnyshell.yaml file, where they have their own kind, named DockerImage.

 

Example

-
    kind: DockerImage
    version: v1
    name: my-app-image
    context: /
    dockerfile: Dockerfile
    target: null
    args:
        ENV: bunnyshell
    secrets:
        NPM_TOKEN: SECRET[abcd123]
    gitRepo: 'https://gitlab.com/example/my-app.git'
    gitBranch: master
    gitApplicationPath: /

Attributes

Docker Image Components have the following attributes:

  • context: the path to the Dockerfile relative to the Git branch.
  • dockerfile: the name of the Dockerfile. This attribute is relative to the context.
  • target: the name of the stage that is to be built from the Dockerfile.
  • args: Docker build args that can be used in the image.
  • secrets: Docker build secrets that can be used in the image.
  • version: Bunnyshell's definition version
  • name: the name
  • gitRepo: the URL of the Git repository where the Dockerfile is located. This field is mandatory.
  • gitBranch: the branch where the Dockerfile is located. This attribute is relative to the gitRepo. This field is mandatory.
  • gitApplicationPath: the path to the application folder, relative to the branch. This field is mandatory.

🚧

Note

If the gitRepo, gitBranch and gitApplicationPath are not provided, Bunnyshell will return an error when trying to validate your environment.

Bunnyshell must have access to the git repository through an existing Git integration (i.e. a Git account that was already connected to Bunnyshell). See the Git Providers page for more information.

 

🚧

Note

Build secrets works only with BuildKit build engine.

Value Interpolation

The images can be used in other components using the following interpolations:

  • {{ components.NAME.image }}: contains full image name, including the tag.
    Example: nginx:latest
  • {{ components.dev_test_image.imageName }}: contains only the image name.
    Example: nginx
  • {{ components.dev_test_image.imageTag }}: contains only the image tag.
    Example: latest

The context, dockerfile, target and args can be used in value interpolation contexts. For args, especially, value interpolation is particularly useful, allowing you to use environment variables as arguments.

 

Resources

The DockerImage component does not produce any deployed resources, just the container images.

Still, the Pod itself that will build the image, will run in the cluster and with the k8s resources specified in the Build Settings.