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

aws_lb_target_group: When type is network, stickiness not supported #2746

Closed
hashibot opened this issue Dec 22, 2017 · 15 comments
Closed

aws_lb_target_group: When type is network, stickiness not supported #2746

hashibot opened this issue Dec 22, 2017 · 15 comments
Labels
bug Addresses a defect in current functionality. service/elbv2 Issues and PRs that pertain to the elbv2 service.
Milestone

Comments

@hashibot
Copy link

This issue was originally opened by @mcraig88 as hashicorp/terraform#16971. It was migrated here as a result of the provider split. The original body of the issue is below.


When using an ALB of type Network, an error is thrown stating that "Network Load Balancers do not support Stickiness" ( I did not define stickiness ). It looks like Stickiness is enabled by default.
When providing the stickiness block as below, I now get another error

Terraform Version

v.0.11.1

...

Terraform Configuration Files

resource "aws_lb_target_group" "serviceLoadBalancer-nlb-targetGroup" {
count = "${lookup(map("true", 0, "false", 1), var.ssl_passthrough_enabled)*(var.load_balancer_type == "network" ? 1 : 0)}"
name = "${var.elb_name_prefix}-elb-target"
port = "${var.service_host_http_port}"
protocol = "TCP"
vpc_id = "${lookup(module.defaultVars.vpc_ids, format("%s.%s", var.aws_account_alias, var.aws_region))}"
deregistration_delay = "${var.target_group_deregistration_delay}"
stickiness {
type = "lb_cookie"
enabled = false
}
}

...

Debug Output

Error: Error running plan: 1 error(s) occurred:

  • module.ecs-http-service.aws_lb_target_group.serviceLoadBalancer-nlb-targetGroup: 1 error(s) occurred:

  • module.ecs-http-service.aws_lb_target_group.serviceLoadBalancer-nlb-targetGroup: Network Load Balancers do not support Stickiness

Expected Behavior

When ALB type of Network, then stickiness should default to false.

Actual Behavior

Stickiness defaults to true.

Steps to Reproduce

Please list the full steps required to reproduce the issue, for example:

  1. terraform init
  2. terraform apply

Important Factoids

References

@dhumraketu
Copy link

I have manually created NLB with exact configuration as shown below and it is working fine.
However, with terraform I am also having the same issue as reported..

By documentation,

  • Default type for load balancer is Application
  • stickiness is supported only for Application Load Balancer
  • stickiness is enabled by default

Now, when creating Network Load Balancer, stickiness is still enabled by default.
And it cannot be disabled because following block is not supported for NLB.

**stickiness {
   type = "lb_cookie"
   enabled = false
}**

Below is my terraform script and the problem is reproducible.

resource "aws_lb" "nlb" {
  load_balancer_type = "network"
  internal        = false
  subnets         = ["${var.public_subnets_id}"]
  enable_deletion_protection = false
}

resource "aws_lb_target_group" "nlb" {
  port = 8080
  protocol = "TCP"
  vpc_id = "${var.vpc_id}"
  target_type = "ip"
}

resource "aws_lb_target_group_attachment" "nlb" {
  availability_zone = "all"
  target_group_arn = "${aws_lb_target_group.nlb.arn}"
  target_id = "${var.host}"
  port = "${var.port}"
}

resource "aws_lb_listener" "nlb" {
  load_balancer_arn = "${aws_lb.nlb.arn}"
  port = 8080
  protocol = "TCP"
  "default_action" {
    target_group_arn = "${aws_lb_target_group.nlb.arn}"
    type = "forward"
  }
}

@LinguineCode
Copy link

+1 for me

@jen20 jen20 added breaking-change Introduces a breaking change in current functionality; usually deferred to the next major release. bug Addresses a defect in current functionality. labels Dec 29, 2017
@jen20
Copy link
Contributor

jen20 commented Dec 29, 2017

Hi @dhumraketu - this is an unfortunate set of defaults which will likely need to be revisited at some point. I'll leave that one to a HashiCorp employee however, since it will likely involve a breaking change.

@whereisaaron
Copy link
Contributor

I am not getting this problem and can create NLBs no problem. The differences I see are

  1. I am using instance targets, not IP target
  2. I am using subnet_mapping blocks rather than subnets

Could be the issue is tied to IP targets?

Terraform v0.11.1
+ provider.aws v1.6.0

@ykrevnyi
Copy link

Workaround:

stickiness = []

Example:

resource "aws_lb_target_group" "nlb" {
  port = 8080
  protocol = "TCP"
  vpc_id = "${var.vpc_id}"

  stickiness = []
}

@rhodrid
Copy link
Contributor

rhodrid commented Feb 9, 2018

Thanks @ykrevnyi. That worked for me.

@vancluever
Copy link
Contributor

Hey all, just an update on this and sorry for the delay in fixing!

So I could not reproduce this using the config here, but I think the core of the problem (judging from the output in the original issue) is that the current validation method for stickiness in ensuring that on TCP target groups, that the block is not present at all, is making this resource tough to write modules for (you would pretty much have to declare the block twice).

#2954 changed this by moving that check up to the enabled attribute of the stickiness block, which helps matters, but still does not fix them 100% as if the block is declared, the data is still added to the API request, which gets rejected because TCP target groups do not support stickiness.

In the spirit of moving this along I have added a commit to #2954 that fixes this, and adds tests and documentation. I want to get more eyes on this from members of the team here that are generally on the AWS provider the most, and then hopefully we can get it merged.

Thanks for your patience on this one and sorry for the delay!

@bflad bflad added this to the v1.10.0 milestone Feb 24, 2018
@bflad bflad removed the breaking-change Introduces a breaking change in current functionality; usually deferred to the next major release. label Feb 24, 2018
@bflad
Copy link
Contributor

bflad commented Feb 24, 2018

The fix for this has been merged into master and will be released in v1.10.0, which I'll be cutting very shortly. Thanks for your patience and the fixes by @mattgiles and @vancluever!

@bflad bflad closed this as completed Feb 24, 2018
@anders1975
Copy link

terraform-provider-aws_v1.10.0_x4

stickiness = []
->
      stickiness.#:                 "1" => "0"
      stickiness.0.cookie_duration: "" => "86400"
      stickiness.0.enabled:         "" => "true"

@grobie
Copy link

grobie commented Mar 8, 2018

@bflad @mattgiles @vancluever The issue still exists in v1.10.0 unfortunately.

resource "aws_lb_target_group" "ampelmann-terminator-tcp-80" {
  name     = "${var.pool_name}-tcp-80"
  port     = 80
  protocol = "TCP"
  vpc_id   = "${var.vpc_id}"

  health_check {
    protocol = "HTTP"
    port     = 8081
    path     = "/health"
    matcher  = "200-399" # do not change
    timeout  = 6         # do not change
  }

  tags {
    Name    = "${aws_lb.ampelmann-terminator.name} - TCP:80"
    Contact = "${var.contact}"
  }
}
* module.ampelmann.aws_lb_target_group.ampelmann-terminator-tcp-80: 1 error(s) occurred:

* module.ampelmann.aws_lb_target_group.ampelmann-terminator-tcp-80: Network Load Balancers do not support Stickiness
$ terraform version
Terraform v0.11.3
+ provider.aws v1.10.0
+ provider.external v1.0.0

@pecigonzalo
Copy link

Did you try setting the stickiness block but to disabled?

@grobie
Copy link

grobie commented Mar 8, 2018

Thanks, that works. I assumed that the fix won't longer enable stickiness by default for network load balancers, but I guess I was mistaken.

@cadavre
Copy link

cadavre commented Nov 30, 2018

The workaround that worked for me was:

  stickiness {
    enabled = false
    type = "lb_cookie"
  }

@zicodes
Copy link

zicodes commented Oct 13, 2019

Commenting this issue as it is occurring with the current Terraform and none of the described workarounds work for me.

Terraform v0.12.10 provider.aws v2.32.0

resource "aws_lb_target_group" "tg_web" {
  name     = "${var.name}"
  port     = "${var.port}"
  protocol = "${var.protocol}"
  vpc_id   = "${var.vpc_id}"
  stickiness = []
}

produces below error:

An argument named "stickiness" is not expected here. Did you mean to define a
block of type "stickiness"?

If I define block stickiness as such:

resource "aws_lb_target_group" "tg_web" {
  name     = "${var.name}"
  port     = "${var.port}"
  protocol = "${var.protocol}"
  vpc_id   = "${var.vpc_id}"

  stickiness {
    enabled = false # stickiness not supported in NLB
    type    = "lb_cookie"
  }
}

I get:

Error: Error modifying Target Group Attributes: InvalidConfigurationRequest: The provided target group attribute is not supported
	status code: 400, request id: d52a5f5c-a967-478c-a902-7d70185d8625

  on ../../modules/tg/main.tf line 4, in resource "aws_lb_target_group" "tg_web":
   4: resource "aws_lb_target_group" "tg_web" {

I have contacted AWS support and they verified that AWS API is receiving the following:

 "eventTime": "2019-10-13T17:38:11Z",
    "eventSource": "elasticloadbalancing.amazonaws.com ",
    "eventName": "ModifyTargetGroupAttributes",
    "awsRegion": "eu-west-1",
    "sourceIPAddress": "xxx",
    "userAgent": "aws-sdk-go/1.25.4 (go1.13; linux; amd64) APN/1.0 HashiCorp/1.0 Terraform/0.12.10 (+https://www.terraform.io)",
    "errorCode": "InvalidConfigurationRequestException",
    "errorMessage": "The provided target group attribute is not supported",
    "requestParameters": {
        "attributes": [
            {
                "value": "300",
                "key": "deregistration_delay.timeout_seconds"
            },
            {
                "value": "false",
                "key": "stickiness.enabled"
            },
            {
                "value": "lb_cookie",
                "key": "stickiness.type"
            },
            {
                "value": "86400",
                "key": "stickiness.lb_cookie.duration_seconds"
            }
        ],
        "targetGroupArn": "arn:aws:elasticloadbalancing:eu-west-1:5xx9883:targetgroup/prod-wp-https-tg/5cfdfxx784aacc"
    },

TCP/TLS target groups cannot have "stickiness" attribute hence the error.

Finally, if I don't include stickiness argument or block, I get:

Error: Network Load Balancers do not support Stickiness

  on ../../modules/tg/main.tf line 4, in resource "aws_lb_target_group" "tg_web":
   4: resource "aws_lb_target_group" "tg_web" {

Which looks like stickiness is enabled by default by Terraform.

Does anyone have a solution for 2019?
Cheers

@ghost
Copy link

ghost commented Nov 1, 2019

I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues.

If you feel this issue should be reopened, we encourage creating a new issue linking back to this one for added context. Thanks!

@ghost ghost locked and limited conversation to collaborators Nov 1, 2019
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
bug Addresses a defect in current functionality. service/elbv2 Issues and PRs that pertain to the elbv2 service.
Projects
None yet
Development

No branches or pull requests