2016-10-28 00:36:26 +00:00
|
|
|
---
|
2020-02-06 23:45:31 +00:00
|
|
|
layout: docs
|
2023-01-30 14:48:43 +00:00
|
|
|
page_title: constraint Block - Job Specification
|
2016-10-28 00:36:26 +00:00
|
|
|
description: |-
|
2023-01-30 14:48:43 +00:00
|
|
|
The "constraint" block allows restricting the set of eligible nodes.
|
2016-10-28 03:01:11 +00:00
|
|
|
Constraints may filter on attributes or metadata. Additionally constraints may
|
|
|
|
be specified at the job, group, or task levels for ultimate flexibility.
|
2016-10-28 00:36:26 +00:00
|
|
|
---
|
|
|
|
|
2023-01-30 14:48:43 +00:00
|
|
|
# `constraint` Block
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
<Placement
|
|
|
|
groups={[
|
|
|
|
['job', 'constraint'],
|
|
|
|
['job', 'group', 'constraint'],
|
2020-09-30 13:48:40 +00:00
|
|
|
['job', 'group', 'task', 'constraint'],
|
2020-02-06 23:45:31 +00:00
|
|
|
]}
|
|
|
|
/>
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2016-10-28 03:01:11 +00:00
|
|
|
The `constraint` allows restricting the set of eligible nodes. Constraints may
|
2016-12-08 18:45:33 +00:00
|
|
|
filter on [attributes][interpolation] or [client metadata][client-meta].
|
|
|
|
Additionally constraints may be specified at the [job][job], [group][group], or
|
|
|
|
[task][task] levels for ultimate flexibility.
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2018-06-19 13:27:16 +00:00
|
|
|
~> **It is possible to define irreconcilable constraints in a job.**
|
|
|
|
For example, because all [tasks within a group are scheduled on the same client node][group],
|
|
|
|
specifying different [`${attr.unique.hostname}`][node-variables] constraints at
|
|
|
|
the task level will cause a job to be unplaceable.
|
|
|
|
|
2016-10-28 00:36:26 +00:00
|
|
|
```hcl
|
|
|
|
job "docs" {
|
|
|
|
# All tasks in this job must run on linux.
|
|
|
|
constraint {
|
|
|
|
attribute = "${attr.kernel.name}"
|
|
|
|
value = "linux"
|
|
|
|
}
|
|
|
|
|
|
|
|
group "example" {
|
|
|
|
# All groups in this job should be scheduled on different hosts.
|
|
|
|
constraint {
|
|
|
|
operator = "distinct_hosts"
|
|
|
|
value = "true"
|
|
|
|
}
|
|
|
|
|
|
|
|
task "server" {
|
|
|
|
# All tasks must run where "my_custom_value" is greater than 3.
|
|
|
|
constraint {
|
2017-01-03 21:25:56 +00:00
|
|
|
attribute = "${meta.my_custom_value}"
|
2016-10-28 00:36:26 +00:00
|
|
|
operator = ">"
|
|
|
|
value = "3"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Placing constraints at both the job level and at the group level is redundant
|
|
|
|
since constraints are applied hierarchically. The job constraints will affect
|
|
|
|
all groups (and tasks) in the job.
|
|
|
|
|
|
|
|
## `constraint` Parameters
|
|
|
|
|
|
|
|
- `attribute` `(string: "")` - Specifies the name or reference of the attribute
|
|
|
|
to examine for the constraint. This can be any of the [Nomad interpolated
|
2023-01-25 17:31:14 +00:00
|
|
|
values](/nomad/docs/runtime/interpolation#interpreted_node_vars).
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2022-09-27 16:07:07 +00:00
|
|
|
- `operator` `(string: "=")` - Specifies the comparison operator. If the operator
|
|
|
|
is one of `>, >=, <, <=`, the ordering is compared numerically if the operands
|
|
|
|
are both integers or both floats, and lexically otherwise. Possible values include:
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```text
|
|
|
|
=
|
|
|
|
!=
|
|
|
|
>
|
|
|
|
>=
|
|
|
|
<
|
|
|
|
<=
|
|
|
|
distinct_hosts
|
|
|
|
distinct_property
|
|
|
|
regexp
|
|
|
|
set_contains
|
2022-05-05 15:11:05 +00:00
|
|
|
set_contains_any
|
2020-02-06 23:45:31 +00:00
|
|
|
version
|
|
|
|
semver
|
|
|
|
is_set
|
|
|
|
is_not_set
|
|
|
|
```
|
|
|
|
|
|
|
|
For a detailed explanation of these values and their behavior, please see
|
|
|
|
the [operator values section](#operator-values).
|
2016-10-28 00:36:26 +00:00
|
|
|
|
|
|
|
- `value` `(string: "")` - Specifies the value to compare the attribute against
|
|
|
|
using the specified operation. This can be a literal value, another attribute,
|
|
|
|
or any [Nomad interpolated
|
2023-01-25 17:31:14 +00:00
|
|
|
values](/nomad/docs/runtime/interpolation#interpreted_node_vars).
|
2016-10-28 00:36:26 +00:00
|
|
|
|
|
|
|
### `operator` Values
|
|
|
|
|
|
|
|
This section details the specific values for the "operator" parameter in the
|
|
|
|
Nomad job specification for constraints. The operator is always specified as a
|
|
|
|
string, but the string can take on different values which change the behavior of
|
|
|
|
the overall constraint evaluation.
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
operator = "..."
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
- `"distinct_hosts"` - Instructs the scheduler to not co-locate any groups on
|
|
|
|
the same machine. When specified as a job constraint, it applies to all groups
|
|
|
|
in the job. When specified as a group constraint, the effect is constrained to
|
2017-03-12 00:18:01 +00:00
|
|
|
that group. This constraint can not be specified at the task level. Note that
|
|
|
|
the `attribute` parameter should be omitted when using this constraint.
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
operator = "distinct_hosts"
|
|
|
|
value = "true"
|
|
|
|
}
|
|
|
|
```
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
The constraint may also be specified as follows for a more compact
|
|
|
|
representation:
|
2017-03-12 00:18:01 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
distinct_hosts = true
|
|
|
|
}
|
|
|
|
```
|
2017-03-12 00:18:01 +00:00
|
|
|
|
|
|
|
- `"distinct_property"` - Instructs the scheduler to select nodes that have a
|
2017-07-31 23:44:17 +00:00
|
|
|
distinct value of the specified property. The `value` parameter specifies how
|
|
|
|
many allocations are allowed to share the value of a property. The `value`
|
2020-02-06 23:45:31 +00:00
|
|
|
must be 1 or greater and if omitted, defaults to 1. When specified as a job
|
2017-07-31 23:44:17 +00:00
|
|
|
constraint, it applies to all groups in the job. When specified as a group
|
|
|
|
constraint, the effect is constrained to that group. This constraint can not
|
2019-11-12 22:32:21 +00:00
|
|
|
be specified at the task level.
|
2017-03-12 00:18:01 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
operator = "distinct_property"
|
|
|
|
attribute = "${meta.rack}"
|
|
|
|
value = "3"
|
|
|
|
}
|
|
|
|
```
|
2017-03-12 00:18:01 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
The constraint may also be specified as follows for a more compact
|
|
|
|
representation:
|
2017-03-12 00:18:01 +00:00
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
distinct_property = "${meta.rack}"
|
|
|
|
value = "3"
|
|
|
|
}
|
|
|
|
```
|
2017-03-12 00:18:01 +00:00
|
|
|
|
2016-10-28 00:36:26 +00:00
|
|
|
- `"regexp"` - Specifies a regular expression constraint against the attribute.
|
|
|
|
The syntax of the regular expressions accepted is the same general syntax used
|
|
|
|
by Perl, Python, and many other languages. More precisely, it is the syntax
|
|
|
|
accepted by RE2 and described at in the [Google RE2
|
|
|
|
syntax](https://golang.org/s/re2syntax).
|
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "..."
|
|
|
|
operator = "regexp"
|
|
|
|
value = "[a-z0-9]"
|
|
|
|
}
|
|
|
|
```
|
2016-10-28 00:36:26 +00:00
|
|
|
|
|
|
|
- `"set_contains"` - Specifies a contains constraint against the attribute. The
|
|
|
|
attribute and the list being checked are split using commas. This will check
|
|
|
|
that the given attribute contains **all** of the specified elements.
|
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "..."
|
|
|
|
operator = "set_contains"
|
|
|
|
value = "a,b,c"
|
|
|
|
}
|
|
|
|
```
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2022-05-05 15:11:05 +00:00
|
|
|
- `"set_contains_any"` - Specifies a contains constraint against the attribute. The
|
|
|
|
attribute and the list being checked are split using commas. This will check
|
|
|
|
that the given attribute contains **any** of the specified elements.
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "..."
|
|
|
|
operator = "set_contains_any"
|
|
|
|
value = "a,b,c"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-10-28 00:36:26 +00:00
|
|
|
- `"version"` - Specifies a version constraint against the attribute. This
|
|
|
|
supports a comma-separated list of constraints, including the pessimistic
|
2019-11-19 18:26:25 +00:00
|
|
|
operator. `version` will not consider a prerelease (eg `1.6.0-beta`)
|
|
|
|
sufficient to match a non-prerelease constraint (eg `>= 1.0`). Use the
|
|
|
|
`semver` constraint for strict [Semantic Versioning 2.0][semver2] ordering.
|
|
|
|
For more examples please see the [go-version
|
2016-10-28 00:36:26 +00:00
|
|
|
repository](https://github.com/hashicorp/go-version) for more specific
|
|
|
|
examples.
|
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "..."
|
|
|
|
operator = "version"
|
|
|
|
value = ">= 0.1.0, < 0.2"
|
|
|
|
}
|
|
|
|
```
|
2016-10-28 00:36:26 +00:00
|
|
|
|
2019-11-19 18:26:25 +00:00
|
|
|
- `"semver"` - Specifies a version constraint against the attribute. Only
|
|
|
|
[Semantic Versioning 2.0][semver2] compliant versions and comparison
|
|
|
|
operators are supported, so there is no pessimistic operator. Unlike `version`,
|
|
|
|
this operator considers prereleases (eg `1.6.0-beta`) sufficient to satisfy
|
|
|
|
non-prerelease constraints (eg `>= 1.0`). _Added in Nomad v0.10.2._
|
|
|
|
|
2020-02-06 23:45:31 +00:00
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "..."
|
|
|
|
operator = "semver"
|
|
|
|
value = ">= 0.1.0, < 0.2"
|
|
|
|
}
|
|
|
|
```
|
2019-11-19 18:26:25 +00:00
|
|
|
|
2018-11-14 03:07:13 +00:00
|
|
|
- `"is_set"` - Specifies that a given attribute must be present. This can be
|
|
|
|
combined with the `"!="` operator to require that an attribute has been set
|
|
|
|
before checking for equality. The default behavior for `"!="` is to include
|
|
|
|
nodes that don't have that attribute set.
|
|
|
|
|
2019-11-12 22:32:21 +00:00
|
|
|
- `"is_not_set"` - Specifies that a given attribute must not be present.
|
2018-11-14 03:07:13 +00:00
|
|
|
|
2016-10-28 00:36:26 +00:00
|
|
|
## `constraint` Examples
|
|
|
|
|
2023-01-30 14:48:43 +00:00
|
|
|
The following examples only show the `constraint` blocks. Remember that the
|
|
|
|
`constraint` block is only valid in the placements listed above.
|
2016-10-28 00:36:26 +00:00
|
|
|
|
|
|
|
### Kernel Data
|
|
|
|
|
|
|
|
This example restricts the task to running on nodes which have a kernel version
|
|
|
|
higher than "3.19".
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "${attr.kernel.version}"
|
|
|
|
operator = "version"
|
|
|
|
value = "> 3.19"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2017-04-24 15:31:20 +00:00
|
|
|
### Distinct Property
|
2017-03-12 00:18:01 +00:00
|
|
|
|
|
|
|
A potential use case of the `distinct_property` constraint is to spread a
|
|
|
|
service with `count > 1` across racks to minimize correlated failure. Nodes can
|
2019-11-12 22:32:21 +00:00
|
|
|
be annotated with which rack they are on using [custom client
|
2018-07-12 09:54:48 +00:00
|
|
|
metadata][client-meta] with values such as "rack-12-1", "rack-12-2", etc.
|
2017-07-31 23:44:17 +00:00
|
|
|
The following constraint would assure that an individual rack is not running
|
|
|
|
more than 2 instances of the task group.
|
2017-03-12 00:18:01 +00:00
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
distinct_property = "${meta.rack}"
|
2017-07-31 23:44:17 +00:00
|
|
|
value = "2"
|
2017-03-12 00:18:01 +00:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-10-28 00:36:26 +00:00
|
|
|
### Operating Systems
|
|
|
|
|
|
|
|
This example restricts the task to running on nodes that are running Ubuntu
|
|
|
|
14.04
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "${attr.os.name}"
|
|
|
|
value = "ubuntu"
|
|
|
|
}
|
|
|
|
|
|
|
|
constraint {
|
|
|
|
attribute = "${attr.os.version}"
|
|
|
|
value = "14.04"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Cloud Metadata
|
|
|
|
|
|
|
|
When possible, Nomad populates node attributes from the cloud environment. These
|
|
|
|
values are accessible as filters in constraints. This example constrains this
|
|
|
|
task to only run on nodes that are memory-optimized on AWS.
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
|
|
|
attribute = "${attr.platform.aws.instance-type}"
|
|
|
|
value = "m4.xlarge"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### User-Specified Metadata
|
|
|
|
|
|
|
|
This example restricts the task to running on nodes where the binaries for
|
|
|
|
redis, cypress, and nginx are all cached locally. This particular example is
|
2019-11-12 22:32:21 +00:00
|
|
|
utilizing [custom client metadata][client-meta].
|
2016-10-28 00:36:26 +00:00
|
|
|
|
|
|
|
```hcl
|
|
|
|
constraint {
|
2017-01-03 21:25:56 +00:00
|
|
|
attribute = "${meta.cached_binaries}"
|
2016-10-28 00:36:26 +00:00
|
|
|
set_contains = "redis,cypress,nginx"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2023-01-25 17:31:14 +00:00
|
|
|
[job]: /nomad/docs/job-specification/job 'Nomad job Job Specification'
|
|
|
|
[group]: /nomad/docs/job-specification/group 'Nomad group Job Specification'
|
|
|
|
[client-meta]: /nomad/docs/configuration/client#meta 'Nomad meta Job Specification'
|
|
|
|
[task]: /nomad/docs/job-specification/task 'Nomad task Job Specification'
|
|
|
|
[interpolation]: /nomad/docs/runtime/interpolation 'Nomad interpolation'
|
|
|
|
[node-variables]: /nomad/docs/runtime/interpolation#node-variables- 'Nomad interpolation-Node variables'
|
|
|
|
[client-meta]: /nomad/docs/configuration/client#custom-metadata-network-speed-and-node-class 'Nomad Custom Metadata, Network Speed, and Node Class'
|
2020-02-06 23:45:31 +00:00
|
|
|
[semver2]: https://semver.org/spec/v2.0.0.html 'Semantic Versioning 2.0'
|