Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Blog - Nomad vs. Kubernetes: Is Simpler Ever Better? #684

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion .github/styles/HouseStyle/tech-terms/general.txt
Original file line number Diff line number Diff line change
Expand Up @@ -546,4 +546,6 @@ prebundled
coroutines
passcode
nvim
Docformatter
multicluster
noncontainerized
Docformatter
110 changes: 110 additions & 0 deletions blog/_posts/2023-10-18-nomad-vs-kubernetes.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
---
title: "Nomad vs. Kubernetes: Is Simpler Ever Better?"
categories:
- Tutorials
toc: true
author: James Konik

internal-links:
- nomad vs kubernetes
- use nomad or kubernetes
- using kubernetes
- using kubernetes or nomad for containers
---

Containers make it easy to deploy software, and container orchestration tools help you manage the complexity as you deploy more of them. But how do you know which container orchestration tool is right for you?

[Kubernetes](https://kubernetes.io) is widely considered [the standard choice](https://devopscube.com/docker-container-clustering-tools/) and has a huge feature set. In contrast, [Nomad](https://www.nomadproject.io) is simpler and, therefore, less powerful. However, it's useful in a wider range of use cases and can handle different workloads.

In this article, you'll learn more about what these tools can do and when you should use each. They'll be compared on how easy they are to set up, what they're like to use, and what the extent of their ecosystem is.

## Getting Started

Both [Nomad](https://github.com/hashicorp/nomad) and [Kubernetes](https://github.com/kubernetes/kubernetes) are open source, and you can choose to self-host or use a managed solution. Depending on which solution you choose, the setup can vary greatly. The latter is easier, although experienced developers may prefer the control of self-hosting. Self-hosting is free, but it's not necessarily cheaper when you factor in development time, maintenance, and hosting costs.

That's especially true in the case of Kubernetes. The [engineering costs of self-hosting](https://tasdikrahman.me/2020/11/27/to-self-host-or-to-not-self-host-your-kubernetes-cluster/) are very likely to outweigh those of a managed service.

<div class="wide">
![Nomad website guidance]({{site.images}}{{page.slug}}/bpff70C.png)
</div>

Nomad provides a [clear download link](https://www.hashicorp.com/products/nomad/pricing) for its self-managed versions, along with a [helpful set of links and tutorials](https://www.nomadproject.io/downloads) to help you get started. You can download binaries for Windows, macOS, and Linux. Or it can be installed as a package, and there's guidance for doing that on macOS and several Linux varieties.

The [Nomad Enterprise](https://www.nomadproject.io/docs/enterprise) version has added support as well as multicluster and governance features.

Nomad can be used on major cloud providers, but it [takes time to set up](https://aws.amazon.com/quickstart/architecture/nomad/). While you do have options, there isn't the range of offerings that you get [with Kubernetes](https://www.qovery.com/blog/kubernetes-vs-nomad-what-to-choose-in-2022).

Kubernetes is also easy to download and install, and offers guidance on its site to do so, although it isn't immediately clear which of the several options available is the best choice for a beginner.

<div class="wide">
![Using kubectl from the command line to create pods]({{site.images}}{{page.slug}}/TNdcKWQ.png)
</div>

There are various tasks to be worked through when self-hosting with Kubernetes, including virtual machine (VM) creation and provisioning. You'll also need to get to know [kubectl](https://kubernetes.io/docs/reference/kubectl/kubectl/) for cluster management. kubectl is a command line utility for working with Kubernetes and is central to many of its workflows.

Learning about these tools takes time, and it's easy to make mistakes with configuration.
There are, however, plenty of services that manage Kubernetes on your behalf. Google, Amazon, and Azure all offer [managed, configurable packages](https://www.qovery.com/blog/kubernetes-vs-nomad-what-to-choose-in-2022) that you can provision and use quickly.

To summarize, you can get started quickly with Nomad, and it's easy to self-host. In comparison, Kubernetes is tougher, and you need expertise or patience to get it up and running. When it comes to managed services, though, Kubernetes has a greater selection of out-of-the-box solutions, particularly on the major cloud providers.

## Ease of Use

<div class="wide">
![Nomad's web interface, showing the **Jobs** screen, courtesy of HashiCorp]({{site.images}}{{page.slug}}/IJWo0df.png)
</div>

Nomad comes with several features ready to use. In addition to [a CLI](https://www.nomadproject.io/docs/commands), there's also a web-based UI for managing and monitoring clusters.

Since it's a self-contained application, it's easy to work with and update. Nomad isn't dependent on other services and [doesn't use third-party storage](https://askanydifference.com/difference-between-nomad-and-kubernetes/), which helps keep it simple. It can be [consistently deployed](https://loft.sh/blog/nomad-vs-kubernetes-picking-the-right-tool-in-2022/) locally and remotely.

In contrast, Kubernetes is more complex than Nomad and uses multiple services together. Google has [acknowledged its complexity](https://www.theregister.com/2021/02/25/google_kubernetes_autopilot/), and if your developers don't have experience with it, they will face a steep learning curve with a lot of configuration. The payoff is that Kubernetes's complexity results in the supported application being [simpler to work with](https://www.appvia.io/blog/why-is-kubernetes-so-complicated), as Kubernetes deals with the hard problems of scaling and load balancing, letting you deploy the application without all the additional complexity.

Kubernetes is managed via the command line. That's all you get out of the box. There's a lot you can do from there, but all the various features it offers require work to set up and configure.

It's a different story with hosted services, however. Many of those offer dashboards that let you manage your clusters easily, and these make Kubernetes's features much more accessible.

Nomad is fundamentally simpler than Kubernetes and easier to install and work with. Kubernetes's complexity makes it more of a challenge; however, software-as-a-service (SaaS) offerings and prebuilt distros make this less of an issue.

## Ecosystem

![Ecosystem]({{site.images}}{{page.slug}}/ecosystem.png)\

Nomad aims for simplicity, and its core is run as a [single binary with no external services required](https://www.nomadproject.io/docs/nomad-vs-kubernetes). It integrates well with HashiCorp's other tools, including [Consul](https://www.consul.io) and [Vault](https://www.vaultproject.io). Vault provides security and secrets management, while Consul lets you automate networking tasks in the cloud.

[Nomad's community](https://www.nomadproject.io/community) includes a forum, and HashiCorp provides some training materials. There are webinars, and you can ask its team questions during office hours. Overall, though, there's not as much as there is with Kubernetes, and much of it is controlled by HashiCorp. However, since Nomad is simpler, that's less of an issue.

Kubernetes is a mature, popular tool and has an active community with [forums](https://discuss.kubernetes.io/), [tutorials](https://kubernetes.io/docs/tutorials/), and [sample projects](https://github.com/kubernetes/examples) galore. Browse [Stack Overflow](https://stackoverflow.com/questions/tagged/kubernetes) or the web in general, and you'll find plenty of discussion on all kinds of related topics. Its [Reddit group](https://www.reddit.com/r/kubernetes/) has around 90,000 members compared to 3,000 for HashiCorp. Its meetups alone have had [over 30,000 participants](https://www.linux.com/news/what-kubernetes/).

You'll find no shortage of people who've faced the same problems as you. This collective experience can be invaluable while taming Kubernetes and getting the most value from it.

In addition, there are many [plug-ins and tools](https://cult.honeypot.io/reads/the-kubernetes-ecosystem/) available to extend Kubernetes. [Helm](https://helm.sh/) is a useful package manager that can help you replicate complicated configurations and maintain consistency across your projects. Moreover, the [Istio](https://istio.io/) service mesh can bring additional security to your services, helping them communicate safely.

Overall, there's more to Kubernetes's ecosystem when compared to Nomad's. However, given the additional complexity of the Kubernetes tool, you'll be more dependent on support than with HashiCorp's simpler product.

## Ideal Use Cases

![Use Cases]({{site.images}}{{page.slug}}/usecases.png)\

Nomad is more than a container orchestration tool, and it can handle other kinds of workloads. Aside from containers, it can manage other types of applications, including noncontainerized [legacy apps](https://www.codemotion.com/magazine/backend/nomad-kubernetes-but-without-the-complexity/). It's also used for edge workload management and batch processing workloads.

If you want to automate the management of different applications, Nomad is perfect. It helps you with scaling and updates, too. It has features for cluster and node management, which make deploying different applications at a scale much easier.

Nomad is ideal if you're interested in scheduling and managing a broad selection of applications. Its clients include [Cloudflare](https://www.cloudflare.com), [Conductor](https://www.conductor.com), and the [Internet Archive](https://archive.org).

Kubernetes is the de facto for large-scale container orchestration deployments. Essentially, that's what it does. It's able to heal applications and [restore failing containers](https://statehub.io/resources/articles/self-healing-in-kubernetes-what-about-the-data/), keeping your infrastructure running smoothly.

It's popular with major companies, and its clients are generally larger than Nomad's. The [case studies page](https://kubernetes.io/case-studies/) on its site includes many large companies, including Adidas, Spotify, and IBM.

Kubernetes has a narrower focus than Nomad but is widely viewed as the best in class at what it does. Kubernetes certainly isn't the easiest tool to use, though. If Nomad can do what you need, its simplicity makes it a better choice.

## Conclusion

Kubernetes has a broad set of features and does almost everything you need to manage containerized applications. If it doesn't do something, you can probably find an extension that does. It's a tightly focused application that does one job really well.

In contrast, Nomad is simple and easy to use. You can use it with a broader selection of use cases, though when compared directly to Kubernetes in container orchestration, it's more limited in what it can do. Which you choose will depend on how much complexity you need, what your future needs are, and what your current development capabilities are.

If you need extensive features or if you think you may need them in the future, Kubernetes is the best choice. If you don't need this functionality or your developers aren't keen to invest time learning Kubernetes, Nomad is a great alternative. Nomad is also the clear choice if you want to use workloads Kubernetes can't handle.

Another tool to be aware of is [Earthly](https://earthly.dev/). It's a CI/CD framework that runs everywhere. Using it gives you builds that are containerized, repeatable, and language-agnostic. It's simple but powerful, so check it out to see how it can help you.

{% include_html cta/bottom-cta.html %}
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading