Use spread to increase failure tolerance
The Nomad scheduler uses a bin-packing algorithm when making job placements on nodes to optimize resource utilization and density of applications. Although bin packing ensures optimal resource utilization, it can lead to some nodes carrying a majority of allocations for a given job. This can cause cascading failures where the failure of a single node or a single data center can lead to application unavailability.
The spread stanza solves this problem by allowing operators to distribute their workloads in a customized way based on attributes and/or client metadata. By using spread criteria in their job specification, Nomad job operators can ensure that failures across a domain such as datacenter or rack don't affect application availability.
Consider a Nomad application that needs to be deployed to multiple datacenters
within a region. Datacenter dc1
has four nodes while dc2
has one node. This
application has ten instances and seven of them must be deployed to dc1
since
it receives more user traffic and you need to make sure the application doesn't
suffer downtime due to not enough running instances to process requests. The
remaining 3 allocations can be deployed to dc2
.
Use the spread
stanza in the Nomad job specification to
ensure the 70% of the workload is being placed in datacenter dc1
and 30% is
being placed in dc2
. The Nomad operator can use the percent option with a
target to customize the spread.
Prerequisites
To perform the tasks described in this guide, you need to have a Nomad environment with Consul installed. You can use this repository to provision a sandbox environment. This tutorial will assume a cluster with one server node and five client nodes.
Tip
This tutorial is for demo purposes and is only using a single server node. In a production cluster, 3 or 5 server nodes are recommended.
Place one of the client nodes in a different datacenter
In this guide, you are going to customize the spread for our job placement
between the datacenters our nodes are located in. Choose one of your client
nodes and edit /etc/nomad.d/nomad.hcl
to change its location to dc2
. A
snippet of an example configuration file is show below with the required change
is shown below.
After making the change on your chosen client node, restart the Nomad service
If everything is configured correctly, you should be able to run the nomad node status
command and confirm that one of your nodes is now in
datacenter dc2
.
Create a job with the spread stanza
Create a file with the name redis.nomad.hcl
and place the following content in it:
Note that the job specifies the spread
stanza and specified the
datacenter attribute while targeting dc1
and dc2
with the
percent options. This will tell the Nomad scheduler to make an attempt to
distribute 70% of the workload on dc1
and 30% of the workload on dc2
.
Register the redis.nomad.hcl job
Run the Nomad job with the following command:
Note that three of the ten allocations have been placed on node 5d16d949
. This
is the node configured to be in datacenter dc2
. The Nomad scheduler has
distributed 30% of the workload to dc2
as specified in the spread
stanza.
Keep in mind that the Nomad scheduler still factors in other components into the overall scoring of nodes when making placements, so you should not expect the spread stanza to strictly implement your distribution preferences like a constraint. Now, take a detailed look at the scoring in the next few steps.
Check the status of the job
Check the status of the job and verify where allocations have been placed. Run the following command:
The output should list ten running instances of your job in the Summary
section as show below:
You can cross-check this output with the results of the nomad node status
command to verify that 30% of your workload has been placed on the node in dc2
(in our case, that node is 5d16d949
).
Obtain detailed scoring information on job placement
The Nomad scheduler will not always spread your workload in the way you have
specified in the spread
stanza even if the resources are available. This is
because spread scoring is factored in with other metrics as well before making a
scheduling decision. In this step, you will take a look at some of those other
factors.
Using the output from the previous step, take any allocation that has been
placed on a node and use the nomad alloc status command with the
verbose option to obtain detailed scoring information on it. In this
example, the tutorial refers to allocation ID 0638edf2
—your allocation IDs will
be different.
The resulting output will show the Placement Metrics
section at the bottom.
Note that the results from the allocation-spread
, binpack
,
job-anti-affinity
, node-reschedule-penalty
, and node-affinity
columns are
combined to produce the numbers listed in the final score
column for each
node. The Nomad scheduler uses the final score for each node in deciding where
to make placements.
Next steps
Change the values of the percent
options on your targets in the spread
stanza and observe how the placement behavior along with the final score given
to each node changes (use the nomad alloc status
command as shown in the
previous step).
Reference material
- The spread stanza documentation
- Scheduling with Nomad