-
Notifications
You must be signed in to change notification settings - Fork 988
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
Internal neg annotation on service is not ignored #445
Comments
Please update the provider to version 1.7.0 because 1.6.2 doesn't contain the fix for internal annotation handling. |
After updating to terraform v0.12 and updating the provider to 1.7.0 it's still failing, this shows up after every plan / apply. See output below: Terraform v0.12.0
+ provider.kubernetes v1.7.0 ~ resource "kubernetes_service" "example" {
id = "default/example"
load_balancer_ingress = []
~ metadata {
~ annotations = {
"cloud.google.com/neg" = jsonencode(
{
ingress = true
}
)
- "cloud.google.com/neg-status" = jsonencode(
{
- network_endpoint_groups = {
- 80 = "k8s1-71f753e6-default-example-80-9b3d0709"
}
- zones = [
- "europe-west1-b",
- "europe-west1-c",
- "europe-west1-d",
]
}
) -> null
} |
Yes, this is expected since “cloud.google.com” is not considered an „internal” annotation namespace. |
resource "kubernetes_service" "example" {
metadata {
name = "${var.service-name}"
labels = {
name = "${var.service-name}"
}
annotations = {
"cloud.google.com/neg" = "{\"ingress\": true}"
}
}
spec {
type = "NodePort"
session_affinity = "None"
port {
port = 80
target_port = "${var.container-port}"
protocol = "TCP"
}
selector = {
name = "${var.service-name}"
}
}
} |
Any progress/thoughts on this? Still "broken" in latest:
I think that specific annotation will just need to be ignored because of how it's used by GCP/GKE. It feels dirty, but I'm not sure if there's a better option. As a workaround you can ignore all annotation changes for now by adding resource "kubernetes_service" "example" {
lifecycle {
ignore_changes = [
metadata[0].annotations,
metadata[0].annotations["cloud.google.com/neg-status"]
]
}
metadata {
name = "${local.name}"
annotations = {
// NOTE: comment out the `ignore_changes` above if adding/removing values here
"cloud.google.com/neg" = "{\"ingress\": true}"
}
}
// ...
} |
I confirm the issue in the following scenario.
The affected resource "kubernetes_service" "app" {
count = var.cluster_enabled ? 1 : 0
metadata {
name = var.app_name
namespace = local.kubernetes_namespace
labels = {
"app" = var.app_name
}
annotations = {
"cloud.google.com/neg" = "{\"exposed_ports\": {\"80\":{}}}"
}
}
spec {
type = "ClusterIP"
selector = {
"app" = var.app_name
}
port {
port = 80
protocol = "TCP"
target_port = local.app_pod_port
}
}
lifecycle {
ignore_changes = [
// TODO Exclude all annotations due to ignoring specific annotations is currently not supported by the provider (https://github.com/terraform-providers/terraform-provider-kubernetes/issues/445)
//metadata[0].annotations,
metadata[0].annotations["cloud.google.com/neg-status"]
]
}
} yields the follwing plan when not ignoring all annotations
|
Can this issue be made a priority as I can't ignore ALL changes to annotations as annotations are likely to change between config This issue still affect version 1.11.1 |
I have ran into this issue trying to filter certain labels and annotations.
A fix for this would be great. |
Same problem |
Same issue with
|
Although changing the neg-status annotation is non-destructive, it is very annoying that the terraform reports 'updates' for things that are internal. Moreover in apps like ours where we have 10 or 12 of them from different modules, the volume of "diffs" caused by this is so large as to make a plan unreadable. This makes the process of debugging a plan very difficult because it is full of stuff that doesn't represent the change that is being applied. For that reason alone, imo, this should be addressed fairly soon. For clarity there are two issues from my perspective: 1) GKE 'creating a specific annotation by default kind of makes it an internal, and should be treated as such 2) not having the ability to ignore specific annotations within the lifecycle model is a problem (which may be out of scope for this team as I suspect that may have more to do with the internals of terraform rather than the k8s module, but it's worth noting. |
You should be able to ignore this annotation using the lifecycle feature, if you check out this example: #741 (comment) You need to create an empty value for the annotation initially so the lifecycle feature is able to pick up the annotation. |
Closing based on @jrhouston's response. Let me know if this is still an issue. |
This has become an issue with GKE 1.17 -- Setting "neg-status" to a blank value and ignore_annotations off is no longer an option because GKE removes a neg-status annotation when there is no ingress defined. Also in 1.17, NEGs are created for all services, with or without an ingress. So "cloud.google.com/neg" is created anyway. That's controllable, however neg-status isn't created and is automatically removed if there's no ingress. You'll only need the ingress if you want an external load balancer instead of an internal cluster service. On 1.16 and lower, the workaround works; but on 1.17 the workaround still results in an update to the service every time because GKE pulls the annotation off and Terraform wants to re-add it so that it can ignore it. |
This is pretty annoying. i'm using rancher, which will add a lot annotations, so i have to configure every possible to exclude. 😢 |
We are tracking the overall changes necessary to close this in #746. Closing in favour of the more holistic solution being planned in 746. |
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. If you feel I made an error 🤖 🙉 , please reach out to my human friends 👉 [email protected]. Thanks! |
Terraform Version
Terraform v0.11.13
provider.kubernetes v1.6.2
Affected Resource(s)
kubernetes_service
Terraform Configuration Files
Expected Behavior
After applying this resource and doing another plan without any changes the expected behavior is: "No changes. Infrastructure is up-to-date."
Actual Behavior
Steps to Reproduce
Set up a service with the
"cloud.google.com/neg" = "{\"ingress\": true}"
annotationImportant Factoids
Running on GKE using https://cloud.google.com/load-balancing/docs/negs/
The text was updated successfully, but these errors were encountered: