Merge pull request #107235 from Nordix/deprecate-loadbalancerip
Deprecate Service.Spec.LoadBalancerIP
This commit is contained in:
		
							
								
								
									
										2
									
								
								api/openapi-spec/swagger.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								api/openapi-spec/swagger.json
									
									
									
										generated
									
									
									
								
							| @@ -10233,7 +10233,7 @@ | |||||||
|           "type": "string" |           "type": "string" | ||||||
|         }, |         }, | ||||||
|         "loadBalancerIP": { |         "loadBalancerIP": { | ||||||
|           "description": "Only applies to Service Type: LoadBalancer LoadBalancer will get created with the IP specified in this field. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.", |           "description": "Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature. Deprecated: This field was under-specified and its meaning varies across implementations, and it cannot support dual-stack. As of Kubernetes v1.24, users are encouraged to use implementation-specific annotations when available. This field may be removed in a future API version.", | ||||||
|           "type": "string" |           "type": "string" | ||||||
|         }, |         }, | ||||||
|         "loadBalancerSourceRanges": { |         "loadBalancerSourceRanges": { | ||||||
|   | |||||||
| @@ -5959,7 +5959,7 @@ | |||||||
|             "type": "string" |             "type": "string" | ||||||
|           }, |           }, | ||||||
|           "loadBalancerIP": { |           "loadBalancerIP": { | ||||||
|             "description": "Only applies to Service Type: LoadBalancer LoadBalancer will get created with the IP specified in this field. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.", |             "description": "Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature. Deprecated: This field was under-specified and its meaning varies across implementations, and it cannot support dual-stack. As of Kubernetes v1.24, users are encouraged to use implementation-specific annotations when available. This field may be removed in a future API version.", | ||||||
|             "type": "string" |             "type": "string" | ||||||
|           }, |           }, | ||||||
|           "loadBalancerSourceRanges": { |           "loadBalancerSourceRanges": { | ||||||
|   | |||||||
| @@ -3840,6 +3840,10 @@ type ServiceSpec struct { | |||||||
| 	// This feature depends on whether the underlying cloud-provider supports specifying | 	// This feature depends on whether the underlying cloud-provider supports specifying | ||||||
| 	// the loadBalancerIP when a load balancer is created. | 	// the loadBalancerIP when a load balancer is created. | ||||||
| 	// This field will be ignored if the cloud-provider does not support the feature. | 	// This field will be ignored if the cloud-provider does not support the feature. | ||||||
|  | 	// Deprecated: This field was under-specified and its meaning varies across implementations, | ||||||
|  | 	// and it cannot support dual-stack. | ||||||
|  | 	// As of Kubernetes v1.24, users are encouraged to use implementation-specific annotations when available. | ||||||
|  | 	// This field may be removed in a future API version. | ||||||
| 	// +optional | 	// +optional | ||||||
| 	LoadBalancerIP string | 	LoadBalancerIP string | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5066,11 +5066,14 @@ message ServiceSpec { | |||||||
|   // +optional |   // +optional | ||||||
|   optional string sessionAffinity = 7; |   optional string sessionAffinity = 7; | ||||||
|  |  | ||||||
|   // Only applies to Service Type: LoadBalancer |   // Only applies to Service Type: LoadBalancer. | ||||||
|   // LoadBalancer will get created with the IP specified in this field. |  | ||||||
|   // This feature depends on whether the underlying cloud-provider supports specifying |   // This feature depends on whether the underlying cloud-provider supports specifying | ||||||
|   // the loadBalancerIP when a load balancer is created. |   // the loadBalancerIP when a load balancer is created. | ||||||
|   // This field will be ignored if the cloud-provider does not support the feature. |   // This field will be ignored if the cloud-provider does not support the feature. | ||||||
|  |   // Deprecated: This field was under-specified and its meaning varies across implementations, | ||||||
|  |   // and it cannot support dual-stack. | ||||||
|  |   // As of Kubernetes v1.24, users are encouraged to use implementation-specific annotations when available. | ||||||
|  |   // This field may be removed in a future API version. | ||||||
|   // +optional |   // +optional | ||||||
|   optional string loadBalancerIP = 8; |   optional string loadBalancerIP = 8; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4358,11 +4358,14 @@ type ServiceSpec struct { | |||||||
| 	// +optional | 	// +optional | ||||||
| 	SessionAffinity ServiceAffinity `json:"sessionAffinity,omitempty" protobuf:"bytes,7,opt,name=sessionAffinity,casttype=ServiceAffinity"` | 	SessionAffinity ServiceAffinity `json:"sessionAffinity,omitempty" protobuf:"bytes,7,opt,name=sessionAffinity,casttype=ServiceAffinity"` | ||||||
|  |  | ||||||
| 	// Only applies to Service Type: LoadBalancer | 	// Only applies to Service Type: LoadBalancer. | ||||||
| 	// LoadBalancer will get created with the IP specified in this field. |  | ||||||
| 	// This feature depends on whether the underlying cloud-provider supports specifying | 	// This feature depends on whether the underlying cloud-provider supports specifying | ||||||
| 	// the loadBalancerIP when a load balancer is created. | 	// the loadBalancerIP when a load balancer is created. | ||||||
| 	// This field will be ignored if the cloud-provider does not support the feature. | 	// This field will be ignored if the cloud-provider does not support the feature. | ||||||
|  | 	// Deprecated: This field was under-specified and its meaning varies across implementations, | ||||||
|  | 	// and it cannot support dual-stack. | ||||||
|  | 	// As of Kubernetes v1.24, users are encouraged to use implementation-specific annotations when available. | ||||||
|  | 	// This field may be removed in a future API version. | ||||||
| 	// +optional | 	// +optional | ||||||
| 	LoadBalancerIP string `json:"loadBalancerIP,omitempty" protobuf:"bytes,8,opt,name=loadBalancerIP"` | 	LoadBalancerIP string `json:"loadBalancerIP,omitempty" protobuf:"bytes,8,opt,name=loadBalancerIP"` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2271,7 +2271,7 @@ var map_ServiceSpec = map[string]string{ | |||||||
| 	"type":                          "type determines how the Service is exposed. Defaults to ClusterIP. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. \"ClusterIP\" allocates a cluster-internal IP address for load-balancing to endpoints. Endpoints are determined by the selector or if that is not specified, by manual construction of an Endpoints object or EndpointSlice objects. If clusterIP is \"None\", no virtual IP is allocated and the endpoints are published as a set of endpoints rather than a virtual IP. \"NodePort\" builds on ClusterIP and allocates a port on every node which routes to the same endpoints as the clusterIP. \"LoadBalancer\" builds on NodePort and creates an external load-balancer (if supported in the current cloud) which routes to the same endpoints as the clusterIP. \"ExternalName\" aliases this service to the specified externalName. Several other fields do not apply to ExternalName services. More info: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types", | 	"type":                          "type determines how the Service is exposed. Defaults to ClusterIP. Valid options are ExternalName, ClusterIP, NodePort, and LoadBalancer. \"ClusterIP\" allocates a cluster-internal IP address for load-balancing to endpoints. Endpoints are determined by the selector or if that is not specified, by manual construction of an Endpoints object or EndpointSlice objects. If clusterIP is \"None\", no virtual IP is allocated and the endpoints are published as a set of endpoints rather than a virtual IP. \"NodePort\" builds on ClusterIP and allocates a port on every node which routes to the same endpoints as the clusterIP. \"LoadBalancer\" builds on NodePort and creates an external load-balancer (if supported in the current cloud) which routes to the same endpoints as the clusterIP. \"ExternalName\" aliases this service to the specified externalName. Several other fields do not apply to ExternalName services. More info: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types", | ||||||
| 	"externalIPs":                   "externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service.  These IPs are not managed by Kubernetes.  The user is responsible for ensuring that traffic arrives at a node with this IP.  A common example is external load-balancers that are not part of the Kubernetes system.", | 	"externalIPs":                   "externalIPs is a list of IP addresses for which nodes in the cluster will also accept traffic for this service.  These IPs are not managed by Kubernetes.  The user is responsible for ensuring that traffic arrives at a node with this IP.  A common example is external load-balancers that are not part of the Kubernetes system.", | ||||||
| 	"sessionAffinity":               "Supports \"ClientIP\" and \"None\". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies", | 	"sessionAffinity":               "Supports \"ClientIP\" and \"None\". Used to maintain session affinity. Enable client IP based session affinity. Must be ClientIP or None. Defaults to None. More info: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies", | ||||||
| 	"loadBalancerIP":                "Only applies to Service Type: LoadBalancer LoadBalancer will get created with the IP specified in this field. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature.", | 	"loadBalancerIP":                "Only applies to Service Type: LoadBalancer. This feature depends on whether the underlying cloud-provider supports specifying the loadBalancerIP when a load balancer is created. This field will be ignored if the cloud-provider does not support the feature. Deprecated: This field was under-specified and its meaning varies across implementations, and it cannot support dual-stack. As of Kubernetes v1.24, users are encouraged to use implementation-specific annotations when available. This field may be removed in a future API version.", | ||||||
| 	"loadBalancerSourceRanges":      "If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.\" More info: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/", | 	"loadBalancerSourceRanges":      "If specified and supported by the platform, this will restrict traffic through the cloud-provider load-balancer will be restricted to the specified client IPs. This field will be ignored if the cloud-provider does not support the feature.\" More info: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/", | ||||||
| 	"externalName":                  "externalName is the external reference that discovery mechanisms will return as an alias for this service (e.g. a DNS CNAME record). No proxying will be involved.  Must be a lowercase RFC-1123 hostname (https://tools.ietf.org/html/rfc1123) and requires `type` to be \"ExternalName\".", | 	"externalName":                  "externalName is the external reference that discovery mechanisms will return as an alias for this service (e.g. a DNS CNAME record). No proxying will be involved.  Must be a lowercase 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.", | 	"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.", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot