Cluster
Cluster
The kubernetes_cluster
resource allows you to create immutable Kubernetes clusters running in Docker containers using K3s.
Image Caching
Kubernetes clusters do not share the local machines Docker image cache. Each node in a cluster has it's own unqiue cache.
To save bandwidth all containers launched in the Kubernetes cluster pulled through an image cache that runs in Docker. After the first pull all images are subsequently pulled from the image cache not the public internet. This cache is global to all Nomad and Kubernetes clusters created with Jumppad.
For more information on the image cache see the container_registry
resource.
Attributes
Attach to the correct network // only when Image is specified
Network attaches the container to an existing network defined in a separate stanza. This block can be specified multiple times to attach the container to multiple networks.
Image defines a Docker image to use when creating the container. By default the kubernetes cluster resource will be created using the latest Jumppad container image.
Nodes nodes
type: int
The number of nodes to create in the cluster.
Additional volume to mount to the server and client nodes.
Docker image in the local Docker image cache to copy to the cluster on creation. This image is added to the Kubernetes clients docker cache enabling jobs to use images that may not be in the local registry.
Jumppad tracks changes to copied images, should the image change running jumppad up would push any changes to the cluster automatically.
A `port` stanza allows you to expose container ports on the local network or host. This stanza can be specified multiple times.
A `port_range` stanza allows you to expose a range of container ports on the local network or host. This stanza can be specified multiple times.
The following example would create 11 ports from 80 to 90 (inclusive) and expose them to the host machine.
Environment environment
type: map[string]string
environment variables to set when starting the container
An env stanza allows you to set environment variables in the container. This stanza can be specified multiple times.
Specifies the configuration for the Kubernetes cluster.
APIPort api_port
type: int
Port to expose the Kubernetes API on the host. By default this uses the standard api port `443`; however, if you are running multiple kubernetes instances you will need to override this value.
ContainerName container_name
type: string
The fully qualified resource name for the Kubernetes cluster, this value can be used to address the server from the Docker network. It is also the name of the Docker container.
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
Meta ID meta.id
string
The full ID of the resource e.g. `resource.type.name`. This is computed from the full resource path:
Meta Type meta.type
string
The type of the resource. This taken from the type label of the resource definition.
Meta Name meta.name
string
The name of the resource. This taken from the name label of the resource definition.
KubeConfig kube_config
type: KubeConfig
Details for the Kubenetes config file that can be used to interact with the cluster.
ConnectorPort connector_port
type: int
The port where the Jumppad connector is exposed to the host, this property is requied by the ingress resource and is not generally needed when building blueprints.
ExternalIP external_ip
type: string
Local IP address of the Nomad server, this property can be used to set the NOAMD_ADDR on the Jumppad client.
Image
Image defines a Docker image used when creating this container. An Image can be stored in a public or a private repository.
Attributes
Name name
required
type: string
Name of the image to use when creating the container, can either be the full canonical name or short name for Docker official images. e.g. `consul:v1.6.1` or `docker.io/consul:v1.6.1`.
Username username
type: string
Username to use when connecting to a private image repository
Password password
type: string
Password to use when connecting to a private image repository, for both username and password interpolated environment variables can be used in place of static values.
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
ID id
type: string
ID is the unique identifier for the image, this is independent of tag and changes each time the image is built. An image that has been tagged multiple times also shares the same ID. ID string `hcl:"id,optional" json:"id,omitempty"`
NetworkAttachment
Network attachment defines a network to which the container is attached.
Attributes
ID id
required
type: string
ID of the network to attach the container to, specified in reference format. e.g. to attach to a network called `cloud`.
IPAddress ip_address
type: string
Static IP address to assign container for the network, the ip address must be within range defined by the network subnet. If this parameter is omitted an IP address will be automatically assigned.
Aliases aliases
type: []string
Aliases allow alternate names to specified for the container. Aliases can be used to reference a container across the network, the container will respond to ping and other network resolution using the primary assigned name `[name].container.shipyard.run` and the aliases.
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
Name name
type: string
Name will equal the name of the network as created by jumppad.
AssignedAddress assigned_address
type: string
`assigned_address` will equal the assigned IP address for the network. This will equal ip_address if set; otherwise, this is the automatically assigned IP address.
Port
A port stanza defines host to container communications
Attributes
Local local
required
type: string
The local port in the container.
Host host
type: string
The host port to map the local port to.
Protocol protocol
type: string
The protocol to use when exposing the port, can be "tcp", or "udp".
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
PortRange
A port_range stanza defines host to container communications by exposing a range of ports for the container.
Attributes
Range range
required
type: string
The port range to expose, e.g, `8080-8082` would expose the ports `8080`, `8081`, `8082`.
EnableHost enable_host
type: bool
Expose the port range on the host.
Protocol protocol
type: string
The protocol to use when exposing the port, can be "tcp", or "udp".
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
Volume
A volume type allows the specification of an attached volume.
Attributes
Source source
required
type: string
The source volume to mount in the container, can be specified as a relative `./` or absolute path `/usr/local/bin`. Relative paths are relative to the file declaring the container.
Destination destination
required
type: string
The destination in the container to mount the volume to, must be an absolute path.
Type type
type: string
The type of the mount, can be one of the following values:
bind: bind the source path to the destination path in the container
volume: source is a Docker volume
tmpfs: create a temporary filesystem
ReadOnly read_only
type: bool
Whether or not the volume is read only.
BindPropagation bind_propagation
type: string
Configures bind propagation for Docker volume mounts, only applies to bind mounts, can be one of the following values:
shared
slave
private
rslave
rprivate
For more information please see the Docker documentation https://docs.docker.com/storage/bind-mounts/#configure-bind-propagation
BindPropagationNonRecursive bind_propagation_non_recursive
type: bool
Configures recursiveness of the bind mount.
By default Docker mounts with the equivalent of mount --rbind
meaning that mounts below the the source directory are visible in the container.
or instance running docker run --rm --mount type=bind,src=/,target=/host,readonly
busybox will make /run
of the host available as/host/run
in the container. To make matters even worse it will be writable (since only the toplevel bind is set readonly, not the children).
If bind_propagation_non_recursive
is set to true then the container will only see an empty /host/run
, meaning thetmpfs
which is typically mounted to /run
on the host is not propagated into the container.
SelinuxRelabel selinux_relabel
type: string
Configures Selinux relabeling for the container (usually specified as :z or :Z) and can be one of the following values:
shared (Equivalent to :z)
private (Equivalent to :Z)
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
ClusterConfig
Specifies the configuration for the Kubernetes cluster.
Attributes
Docker configuration for the Kubernetes cluster.
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
DockerConfig
Specifies the configuration for the Docker engine in the cluster.
Attributes
NoProxy no_proxy
type: []string
A list of docker registries that should not be proxied.
InsecureRegistries insecure_registries
type: []string
A list of insecure docker registries.
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
KubeConfig
Details for the Kubenetes config file that can be used to interact with the cluster.
Attributes
Computed Attributes
These attributes are computed when the config is parsed and applied, and are therefore only known at parsetime or runtime.
ConfigPath path
type: string
The path to the kubeconfig file
CA ca
type: string
The base64 encoded ca certificate
ClientCertificate client_certificate
type: string
The base64 encoded client certificate
ClientKey client_key
type: string
The base64 encoded client key
Examples
Simple cluster
Full Example
Last updated