Skip to content

Latest commit

 

History

History
 
 

docker

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Pulumi Docker images

This image is an alternative to the Pulumi docker image The pulumi/pulumi image is quite large because it has to bundle all the SDKs that Pulumi supports:

  • Go
  • Python
  • NodeJS
  • DotNet

This container is a slimmer container for the specific SDK. It contains the pulumi binary, the pulumi language runtime for that SDK and any additional necessary language components..

Images

We build a matrix of images for differing Pulumi language SDKs and operating systems. The OS base images we use are:

  • registry.access.redhat.com/ubi8/ubi-minimal (ubi)
  • debian:buster-slim (debian)

Base Image

The base image just contains the pulumi binaries and language runtimes, but not the SDK runtimes. If you use the base image, you'll have to install Go/Python/Dotnet/NodeJS yourself. The image format is:

pulumi/pulumi-base:<PULUMI_VERSION>-<OS>

The default image without the OS is based on Debian Buster, and can be used like so:

pulumi/pulumi-base:<PULUMI_VERSION>

SDK Images

Images with the SDK runtimes are generated in the following format:

pulumi/pulumi-<PULUMI_SDK>:<PULUMI_VERSION>-<OS>

The default image without the OS suffix is based on Debian Buster, and can be used like so:

pulumi/pulumi-<PULUMI_SDK>:<PULUMI_VERSION>
pulumi/pulumi-<PULUMI_SDK>:latest

Image Size

Each of the images are much smaller than the combined Pulumi container. They are in the region of approx 150MB (compressed size) depending on the operating system it has been built on

Operating Systems

We currently build images based on both Debian Buster and with the RedHat Universal Base Image/

UBI Images

The UBI images use microdnf as a package manager, not yum. See this page for more information.

Usage

In order to try and keep the images flexible and try to meet as many use cases as possible, none of these images have CMD or entrypoint set, so you'll need to specify the commands you want to run, for example:

docker run -e PULUMI_ACCESS_TOKEN=<TOKEN> -v "$(pwd)":/pulumi/projects $IMG /bin/bash -c "npm ci && pulumi preview -s <stackname>"

Considerations

These images do not include additional tools you might want to use when running a pulumi provider. For example, if you're using the pulumi-kubernetes with Helm, you'll need to use these images as a base image, or install the helm command as part of your CI setup.