/nomad-on-kubernetes

Tutorial on running Nomad on Kubernetes.

Primary LanguageShellApache License 2.0Apache-2.0

Nomad on Kubernetes

The Nomad on Kubernetes tutorial documents how to deploy Nomad on Kubernetes. The following diagram provides a high level overview of the Nomad on Kubernetes architecture.

Nomad on Kubernetes

The following components will be deployed to a Kubernetes cluster with minimal CPU and memory allocations to control cost:

Rationale

Nomad and Kubernetes have many differences in terms of managing applications but have also been found to complement each other. Nomad is workload-agnostic and supports running non-containerized applications -- broadening the type of workloads you can run across your infrastructure. Other components of the Nomad stack such as Consul and Vault can be leveraged directly within Kubernetes. Consul can provide federated service discovery across multiple Kubernetes clusters and existing platforms such as virtual machines. Vault can provide robust secrets management to Kubernetes workloads including dynamic secret generation.

Kubernetes can ease the deployment and management of Nomad and related components by leveraging some of Kubernetes advanced features including:

Tutorial

Clean up

Run the clean-up bash script to remove all compute resources created by this tutorial:

bash clean-up

TODO

  • Verify with the latest version of Go (1.9 at time of writing)
  • Verify with the latest version of Vault (0.8.1 at time of writing)
  • Verify with Vault configured "sudo setcap cap_ipc_lock=+ep $(readlink -f $(which vault))"