2020-07-01 11:03:49 +00:00
|
|
|
---
|
|
|
|
layout: docs
|
|
|
|
page_title: Target
|
|
|
|
sidebar_title: Target
|
|
|
|
description: Target plugins determine where the resource to be autoscaled is located.
|
|
|
|
---
|
|
|
|
|
|
|
|
# Target Plugins
|
|
|
|
|
|
|
|
Target Plugins determine where the resource to be autoscaled is located. All
|
|
|
|
target plugins support the `dry-run` policy config parameter which allows a policy
|
|
|
|
to be evaluated, but will noop any suggested changes.
|
|
|
|
|
|
|
|
## Nomad Task Group Target
|
|
|
|
|
|
|
|
The Nomad task group target indicates the scalable resource is a Nomad job
|
|
|
|
running on a Nomad cluster.
|
|
|
|
|
|
|
|
### Agent Configuration Options
|
|
|
|
|
|
|
|
The Nomad target is automatically launched by the Nomad Autoscaler and so the
|
|
|
|
following setup is optional.
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
target "nomad" {
|
|
|
|
driver = "nomad"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Policy Configuration Options
|
|
|
|
|
|
|
|
If using the [Nomad job specification scaling stanza][nomad_scaling_stanza] to
|
|
|
|
configure the scaling policy, the following section can be omitted as Nomad will
|
|
|
|
populate them on job submission.
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
check {
|
|
|
|
...
|
|
|
|
target "nomad" {
|
|
|
|
Job = "example"
|
|
|
|
Group = "cache"
|
|
|
|
}
|
|
|
|
...
|
|
|
|
```
|
|
|
|
|
|
|
|
- `job` `(string: "") ` - The job identifier which contains the task group to
|
2020-07-08 22:42:41 +00:00
|
|
|
scale as defined within the job specification [`job` stanza][nomad_job_stanza].
|
2020-07-01 11:03:49 +00:00
|
|
|
|
|
|
|
- `group` `(string: "")` - The name of the task group to scale as defined in the
|
2020-07-08 22:42:41 +00:00
|
|
|
job specification [`group` stanza][nomad_group_stanza].
|
2020-07-01 11:03:49 +00:00
|
|
|
|
|
|
|
## AWS AutoScaling Group Target
|
|
|
|
|
|
|
|
The AWS ASG target plugin allows for the scaling of the Nomad cluster clients
|
|
|
|
via manipulating [AWS AutoScaling Groups][aws_autoscaling].
|
|
|
|
|
|
|
|
### Agent Configuration Options
|
|
|
|
|
|
|
|
To use the AWS ASG target plugin, the agent configuration needs to be populated
|
|
|
|
with the appropriate target block. Authentication to the AWS API can be supplied
|
|
|
|
in a number of ways including EC2 instance roles. It is recommended, if possible
|
|
|
|
to use the [Vault AWS Secrets engine][vault_aws_backend] for supplying access
|
|
|
|
credentials to the plugin. Credentials should be injected into the configuration
|
|
|
|
via a template rather than as environment variables. This ensures the credentials
|
|
|
|
are passed only to the plugin, rather than being available for all plugins and
|
|
|
|
the agent process.
|
|
|
|
|
|
|
|
The IAM policy required for the AWS ASG plugin to function properly is detailed
|
|
|
|
below.
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"Version": "2012-10-17",
|
|
|
|
"Statement": [
|
|
|
|
{
|
|
|
|
"Sid": "",
|
|
|
|
"Effect": "Allow",
|
|
|
|
"Action": [
|
|
|
|
"ec2:TerminateInstances",
|
|
|
|
"ec2:DescribeInstanceStatus",
|
|
|
|
"autoscaling:UpdateAutoScalingGroup",
|
|
|
|
"autoscaling:DetachInstances",
|
|
|
|
"autoscaling:DescribeScalingActivities",
|
|
|
|
"autoscaling:DescribeAutoScalingGroups",
|
|
|
|
"autoscaling:CreateOrUpdateTags"
|
|
|
|
],
|
|
|
|
"Resource": "*"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
target "aws-asg" {
|
|
|
|
driver = "aws-asg"
|
|
|
|
config = {
|
|
|
|
aws_region = "eu-west-3"
|
|
|
|
aws_access_key_id = "AKIAIOSFODNN7EXAMPLE"
|
|
|
|
aws_secret_key_id = "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-07-01 13:41:16 +00:00
|
|
|
When using a Nomad cluster with ACLs enabled, the plugin will require an ACL token which provides
|
|
|
|
the following permissions:
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
node {
|
|
|
|
policy = "write"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-07-01 11:03:49 +00:00
|
|
|
- `aws_region` `(string: "us-east-1")` - The [AWS region][aws_region] identifier
|
|
|
|
to connect to and where resources should be managed.
|
|
|
|
|
|
|
|
- `aws_access_key_id` `(string: "")` - The AWS access key ID used to authenticate
|
|
|
|
with the AWS API.
|
|
|
|
|
|
|
|
- `aws_secret_key_id` `(string: "")` - The AWS secret key ID used to authenticate
|
|
|
|
with the AWS API.
|
|
|
|
|
|
|
|
- `aws_session_token` `(string: "")` - The AWS session token used to authenticate
|
|
|
|
with the AWS API.
|
|
|
|
|
|
|
|
### Policy Configuration Options
|
|
|
|
|
|
|
|
```hcl
|
|
|
|
check {
|
|
|
|
...
|
|
|
|
target "aws-asg" {
|
2020-07-01 13:41:16 +00:00
|
|
|
aws_asg_name = "hashistack-client-asg"
|
|
|
|
node_class = "hashistack"
|
|
|
|
node_drain_deadline = "5m"
|
2020-07-01 11:03:49 +00:00
|
|
|
}
|
|
|
|
...
|
|
|
|
```
|
|
|
|
|
2020-09-02 12:03:35 +00:00
|
|
|
- `aws_asg_name` `(string: <required>)` - The name of the AWS AutoScaling Group to
|
2020-07-01 11:03:49 +00:00
|
|
|
interact with when performing scaling actions.
|
|
|
|
|
2020-09-02 12:03:35 +00:00
|
|
|
- `node_class` `(string: <required>)` - The Nomad [client node class][nomad_node_class]
|
2020-07-01 11:03:49 +00:00
|
|
|
identifier used to group nodes into a pool of resource.
|
|
|
|
|
2020-09-02 12:03:35 +00:00
|
|
|
- `node_drain_deadline` `(duration: "15m")` The Nomad [drain deadline][nomad_node_drain_deadline]
|
2020-07-01 11:03:49 +00:00
|
|
|
to use when performing node draining actions.
|
|
|
|
|
|
|
|
[nomad_node_class]: https://www.nomadproject.io/docs/configuration/client#node_class
|
|
|
|
[nomad_node_drain_deadline]: https://www.nomadproject.io/api-docs/nodes#deadline
|
|
|
|
[nomad_scaling_stanza]: /docs/job-specification/scaling
|
2020-07-08 22:42:41 +00:00
|
|
|
[nomad_group_stanza]: /docs/job-specification/group#group-stanza
|
2020-07-01 11:03:49 +00:00
|
|
|
[nomad_job_stanza]: /docs/job-specification/job#job-stanza
|
|
|
|
[aws_region]: https://aws.amazon.com/about-aws/global-infrastructure/regions_az/
|
|
|
|
[aws_autoscaling]: https://aws.amazon.com/autoscaling/
|
|
|
|
[vault_aws_backend]: https://www.vaultproject.io/docs/secrets/aws
|