Initial spread docs
This commit is contained in:
parent
1c2fec824f
commit
12dddcc525
117
website/source/docs/job-specification/spread.html.md
Normal file
117
website/source/docs/job-specification/spread.html.md
Normal file
|
@ -0,0 +1,117 @@
|
||||||
|
---
|
||||||
|
layout: "docs"
|
||||||
|
page_title: "spread Stanza - Job Specification"
|
||||||
|
sidebar_current: "docs-job-specification-spread"
|
||||||
|
description: |-
|
||||||
|
The "spread" stanza allows operators to configure desired target percentages for allocations according to node attributes or metadata.
|
||||||
|
Spread may be specified at the job, group, or task levels for ultimate flexibility.
|
||||||
|
More than one spread stanza may be specified with relative weights between each.
|
||||||
|
---
|
||||||
|
|
||||||
|
# `spread` Stanza
|
||||||
|
|
||||||
|
<table class="table table-bordered table-striped">
|
||||||
|
<tr>
|
||||||
|
<th width="120">Placement</th>
|
||||||
|
<td>
|
||||||
|
<code>job -> **spread**</code>
|
||||||
|
<br>
|
||||||
|
<code>job -> group -> **spread**</code>
|
||||||
|
<br>
|
||||||
|
<code>job -> group -> task -> **spread**</code>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
The `spread` stanza allows operators to specify target percentages of allocations according to
|
||||||
|
specific node attributes or metadata. Spread may
|
||||||
|
be expressed on [attributes][interpolation] or [client metadata][client-meta].
|
||||||
|
Additionally spread may be specified at the [job][job], [group][group], or
|
||||||
|
[task][task] levels for ultimate flexibility.
|
||||||
|
|
||||||
|
Nomad will use any defined spread criteria when computing node scores for placement.
|
||||||
|
Nodes are scored acccording to how closely they match the desired target percentage defined in the
|
||||||
|
spread stanza. Spread scores are combined with other scoring factors such as bin packing.
|
||||||
|
|
||||||
|
A job or task group can have more than one spread criteria, with weights to express relative preference.
|
||||||
|
|
||||||
|
Spread criteria are treated as a soft preference by the Nomad scheduler. If no nodes match a given spread criteria, placement is still successful.
|
||||||
|
|
||||||
|
## `spread` Parameters
|
||||||
|
|
||||||
|
- `attribute` `(string: "")` - Specifies the name or reference of the attribute
|
||||||
|
to use. This can be any of the [Nomad interpolated
|
||||||
|
values](/docs/runtime/interpolation.html#interpreted_node_vars).
|
||||||
|
|
||||||
|
- `target` <code>([target](#target-parameters): <required>)</code> - Specifies one or more target
|
||||||
|
percentages for each value of the `attribute` in the spread stanza. If this is omitted,
|
||||||
|
Nomad will spread allocations evenly across all values of the attribute.
|
||||||
|
|
||||||
|
- `weight` `(integer:0)` - Specifies a weight for the spread stanza. The weight is used
|
||||||
|
during scoring and must be an integer between -100 to 100. Weights can be used
|
||||||
|
when there is more than one spread or affinity stanza to express relative preference across them.
|
||||||
|
|
||||||
|
## `target` Parameters
|
||||||
|
|
||||||
|
- `value` `(string:"")` - Specifies a target value of the attribute from a `spread` stanza.
|
||||||
|
|
||||||
|
- `percent` `(integer:0)` - Specifies the percentage associated with the target value.
|
||||||
|
|
||||||
|
## `spread` Examples
|
||||||
|
|
||||||
|
The following examples show different ways to use the `spread` stanza.
|
||||||
|
|
||||||
|
### Even Spread Across Data Center
|
||||||
|
|
||||||
|
This example shows a spread stanza across the node's `datacenter` attribute. Allocations
|
||||||
|
are placed evenly across all datacenters with this example.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
spread {
|
||||||
|
attribute = "${node.datacenter}"
|
||||||
|
weight = 100
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Spread With Target Percentages
|
||||||
|
|
||||||
|
This example shows a spread stanza that specifies target percentages for two
|
||||||
|
different datacenters.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
spread {
|
||||||
|
attribute = "${node.datacenter}"
|
||||||
|
weight = 100
|
||||||
|
target "us-east1" {
|
||||||
|
percent = 60
|
||||||
|
}
|
||||||
|
target "us-west1" {
|
||||||
|
percent = 40
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Spread Across Multiple Attributes
|
||||||
|
|
||||||
|
This example shows spread stanzas with multiple attributes
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
spread {
|
||||||
|
attribute = "${node.datacenter}"
|
||||||
|
weight = 50
|
||||||
|
}
|
||||||
|
spread {
|
||||||
|
attribute = "${meta.rack}"
|
||||||
|
weight = 50
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
[job]: /docs/job-specification/job.html "Nomad job Job Specification"
|
||||||
|
[group]: /docs/job-specification/group.html "Nomad group Job Specification"
|
||||||
|
[client-meta]: /docs/configuration/client.html#meta "Nomad meta Job Specification"
|
||||||
|
[task]: /docs/job-specification/task.html "Nomad task Job Specification"
|
||||||
|
[interpolation]: /docs/runtime/interpolation.html "Nomad interpolation"
|
||||||
|
[node-variables]: /docs/runtime/interpolation.html#node-variables- "Nomad interpolation-Node variables"
|
||||||
|
[constraint]: /docs/job-specification/constraint.html "Nomad Constraint job Specification"
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue