Merge pull request #63742 from thockin/kill-tolerate-unready-annotation
Automatic merge from submit-queue (batch tested with PRs 63792, 63495, 63742, 63332, 63779). If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Actually support service `publishNotReadyAddresses` This was added and the annotation was deprecated, but it was never implemented. xref #63741 **Release note**: ```release-note The annotation `service.alpha.kubernetes.io/tolerate-unready-endpoints` is deprecated. Users should use Service.spec.publishNotReadyAddresses instead. ```
This commit is contained in:
		
							
								
								
									
										2
									
								
								api/openapi-spec/swagger.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								api/openapi-spec/swagger.json
									
									
									
										generated
									
									
									
								
							| @@ -80410,7 +80410,7 @@ | ||||
|       "x-kubernetes-patch-strategy": "merge" | ||||
|      }, | ||||
|      "publishNotReadyAddresses": { | ||||
|       "description": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery. This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints when that annotation is deprecated and all clients have been converted to use this field.", | ||||
|       "description": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery.", | ||||
|       "type": "boolean" | ||||
|      }, | ||||
|      "selector": { | ||||
|   | ||||
							
								
								
									
										2
									
								
								api/swagger-spec/v1.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								api/swagger-spec/v1.json
									
									
									
										generated
									
									
									
								
							| @@ -22696,7 +22696,7 @@ | ||||
|      }, | ||||
|      "publishNotReadyAddresses": { | ||||
|       "type": "boolean", | ||||
|       "description": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery. This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints when that annotation is deprecated and all clients have been converted to use this field." | ||||
|       "description": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery." | ||||
|      }, | ||||
|      "sessionAffinityConfig": { | ||||
|       "$ref": "v1.SessionAffinityConfig", | ||||
|   | ||||
							
								
								
									
										2
									
								
								docs/api-reference/v1/definitions.html
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								docs/api-reference/v1/definitions.html
									
									
									
										generated
									
									
									
								
							| @@ -6146,7 +6146,7 @@ Examples:<br> | ||||
| </tr> | ||||
| <tr> | ||||
| <td class="tableblock halign-left valign-top"><p class="tableblock">publishNotReadyAddresses</p></td> | ||||
| <td class="tableblock halign-left valign-top"><p class="tableblock">publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet’s Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery. This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints when that annotation is deprecated and all clients have been converted to use this field.</p></td> | ||||
| <td class="tableblock halign-left valign-top"><p class="tableblock">publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet’s Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery.</p></td> | ||||
| <td class="tableblock halign-left valign-top"><p class="tableblock">false</p></td> | ||||
| <td class="tableblock halign-left valign-top"><p class="tableblock">boolean</p></td> | ||||
| <td class="tableblock halign-left valign-top"><p class="tableblock">false</p></td> | ||||
|   | ||||
| @@ -3053,9 +3053,6 @@ type ServiceSpec struct { | ||||
| 	// The primary use case for setting this field is to use a StatefulSet's Headless Service | ||||
| 	// to propagate SRV records for its Pods without respect to their readiness for purpose | ||||
| 	// of peer discovery. | ||||
| 	// This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints | ||||
| 	// when that annotation is deprecated and all clients have been converted to use this | ||||
| 	// field. | ||||
| 	// +optional | ||||
| 	PublishNotReadyAddresses bool | ||||
| } | ||||
|   | ||||
| @@ -64,7 +64,7 @@ const ( | ||||
| 	// containers in the pod and marks it "Running", till the kubelet stops all | ||||
| 	// containers and deletes the pod from the apiserver. | ||||
| 	// This field is deprecated. v1.Service.PublishNotReadyAddresses will replace it | ||||
| 	// subsequent releases. | ||||
| 	// subsequent releases.  It will be removed no sooner than 1.13. | ||||
| 	TolerateUnreadyEndpointsAnnotation = "service.alpha.kubernetes.io/tolerate-unready-endpoints" | ||||
| ) | ||||
|  | ||||
| @@ -420,7 +420,8 @@ func (e *EndpointController) syncService(key string) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	var tolerateUnreadyEndpoints bool | ||||
| 	// If the user specified the older (deprecated) annotation, we have to respect it. | ||||
| 	tolerateUnreadyEndpoints := service.Spec.PublishNotReadyAddresses | ||||
| 	if v, ok := service.Annotations[TolerateUnreadyEndpointsAnnotation]; ok { | ||||
| 		b, err := strconv.ParseBool(v) | ||||
| 		if err == nil { | ||||
|   | ||||
| @@ -4101,9 +4101,6 @@ message ServiceSpec { | ||||
|   // The primary use case for setting this field is to use a StatefulSet's Headless Service | ||||
|   // to propagate SRV records for its Pods without respect to their readiness for purpose | ||||
|   // of peer discovery. | ||||
|   // This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints | ||||
|   // when that annotation is deprecated and all clients have been converted to use this | ||||
|   // field. | ||||
|   // +optional | ||||
|   optional bool publishNotReadyAddresses = 13; | ||||
|  | ||||
|   | ||||
| @@ -3362,9 +3362,6 @@ type ServiceSpec struct { | ||||
| 	// The primary use case for setting this field is to use a StatefulSet's Headless Service | ||||
| 	// to propagate SRV records for its Pods without respect to their readiness for purpose | ||||
| 	// of peer discovery. | ||||
| 	// This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints | ||||
| 	// when that annotation is deprecated and all clients have been converted to use this | ||||
| 	// field. | ||||
| 	// +optional | ||||
| 	PublishNotReadyAddresses bool `json:"publishNotReadyAddresses,omitempty" protobuf:"varint,13,opt,name=publishNotReadyAddresses"` | ||||
| 	// sessionAffinityConfig contains the configurations of session affinity. | ||||
|   | ||||
| @@ -2020,7 +2020,7 @@ var map_ServiceSpec = map[string]string{ | ||||
| 	"externalName":             "externalName is the external reference that kubedns or equivalent will return as a CNAME record for this service. No proxying will be involved. Must be a valid RFC-1123 hostname (https://tools.ietf.org/html/rfc1123) and requires Type to be ExternalName.", | ||||
| 	"externalTrafficPolicy":    "externalTrafficPolicy denotes if this Service desires to route external traffic to node-local or cluster-wide endpoints. \"Local\" preserves the client source IP and avoids a second hop for LoadBalancer and Nodeport type services, but risks potentially imbalanced traffic spreading. \"Cluster\" obscures the client source IP and may cause a second hop to another node, but should have good overall load-spreading.", | ||||
| 	"healthCheckNodePort":      "healthCheckNodePort specifies the healthcheck nodePort for the service. If not specified, HealthCheckNodePort is created by the service api backend with the allocated nodePort. Will use user-specified nodePort value if specified by the client. Only effects when Type is set to LoadBalancer and ExternalTrafficPolicy is set to Local.", | ||||
| 	"publishNotReadyAddresses": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery. This field will replace the service.alpha.kubernetes.io/tolerate-unready-endpoints when that annotation is deprecated and all clients have been converted to use this field.", | ||||
| 	"publishNotReadyAddresses": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery.", | ||||
| 	"sessionAffinityConfig":    "sessionAffinityConfig contains the configurations of session affinity.", | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -9,13 +9,6 @@ metadata: | ||||
|   labels: | ||||
|     app: cockroachdb | ||||
|   annotations: | ||||
|     # This is needed to make the peer-finder work properly and to help avoid | ||||
|     # edge cases where instance 0 comes up after losing its data and needs to | ||||
|     # decide whether it should create a new cluster or try to join an existing | ||||
|     # one. If it creates a new cluster when it should have joined an existing | ||||
|     # one, we'd end up with two separate clusters listening at the same service | ||||
|     # endpoint, which would be very bad. | ||||
|     service.alpha.kubernetes.io/tolerate-unready-endpoints: "true" | ||||
|     # Enable automatic monitoring of all instances when Prometheus is running in the cluster. | ||||
|     prometheus.io/scrape: "true" | ||||
|     prometheus.io/path: "_status/vars" | ||||
| @@ -31,3 +24,10 @@ spec: | ||||
|   clusterIP: None | ||||
|   selector: | ||||
|     app: cockroachdb | ||||
|   # This is needed to make the peer-finder work properly and to help avoid | ||||
|   # edge cases where instance 0 comes up after losing its data and needs to | ||||
|   # decide whether it should create a new cluster or try to join an existing | ||||
|   # one. If it creates a new cluster when it should have joined an existing | ||||
|   # one, we'd end up with two separate clusters listening at the same service | ||||
|   # endpoint, which would be very bad. | ||||
|   publishNotReadyAddresses: true | ||||
|   | ||||
| @@ -1,8 +1,5 @@ | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   annotations: | ||||
|     service.alpha.kubernetes.io/tolerate-unready-endpoints: "true" | ||||
| metadata: | ||||
|   name: etcd | ||||
|   labels: | ||||
| @@ -16,3 +13,4 @@ spec: | ||||
|   clusterIP: None | ||||
|   selector: | ||||
|     app: etcd | ||||
|   publishNotReadyAddresses: true | ||||
|   | ||||
| @@ -2,8 +2,6 @@ | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   annotations: | ||||
|     service.alpha.kubernetes.io/tolerate-unready-endpoints: "true" | ||||
|   name: galera | ||||
|   labels: | ||||
|     app: mysql | ||||
| @@ -15,4 +13,4 @@ spec: | ||||
|   clusterIP: None | ||||
|   selector: | ||||
|     app: mysql | ||||
|  | ||||
|   publishNotReadyAddresses: true | ||||
|   | ||||
| @@ -2,8 +2,6 @@ | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   annotations: | ||||
|     service.alpha.kubernetes.io/tolerate-unready-endpoints: "true" | ||||
|   name: redis | ||||
|   labels: | ||||
|     app: redis | ||||
| @@ -15,4 +13,3 @@ spec: | ||||
|   clusterIP: None | ||||
|   selector: | ||||
|     app: redis | ||||
|  | ||||
|   | ||||
| @@ -2,8 +2,6 @@ | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   annotations: | ||||
|     service.alpha.kubernetes.io/tolerate-unready-endpoints: "true" | ||||
|   name: zk | ||||
|   labels: | ||||
|     app: zk | ||||
| @@ -17,4 +15,4 @@ spec: | ||||
|   clusterIP: None | ||||
|   selector: | ||||
|     app: zk | ||||
|  | ||||
|   publishNotReadyAddresses: true | ||||
|   | ||||
| @@ -6,7 +6,7 @@ All it does is watch DNS for changes in the set of endpoints that are part of th | ||||
| of the PetSet.  It periodically looks up the SRV record of the DNS entry that corresponds to a Kubernetes | ||||
| Service which enumerates the set of peers for this  the specified service. | ||||
|  | ||||
| Be sure to use the `service.alpha.kubernetes.io/tolerate-unready-endpoints` on the governing service | ||||
| Be sure to use the `publishNotReadyAddresses` field on the governing service | ||||
| of the StatefulSet so that all peers are listed in endpoints before any peers are started. | ||||
|  | ||||
| There are several ways to bundle it with your main application. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Submit Queue
					Kubernetes Submit Queue