Skip to content

Commit

Permalink
fix/optimize the logic of finding cluster service/pod ip range
Browse files Browse the repository at this point in the history
  • Loading branch information
unilinu committed Dec 4, 2024
1 parent edbfda0 commit 66c3f51
Showing 1 changed file with 14 additions and 32 deletions.
46 changes: 14 additions & 32 deletions pkg/discovery/network/generic.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,11 @@ func findClusterIPRange(ctx context.Context, client controllerClient.Client) (st
return clusterIPRange, err
}

clusterIPRange, err = findClusterIPRangeFromKubeController(ctx, client)
if err != nil || clusterIPRange != "" {
return clusterIPRange, err
}

clusterIPRange, err = findClusterIPRangeFromServiceCreation(ctx, client)
if err != nil || clusterIPRange != "" {
return clusterIPRange, err
Expand All @@ -94,6 +99,10 @@ func findClusterIPRangeFromApiserver(ctx context.Context, client controllerClien
return FindPodCommandParameter(ctx, client, "component=kube-apiserver", "--service-cluster-ip-range")
}

func findClusterIPRangeFromKubeController(ctx context.Context, client controllerClient.Client) (string, error) {
return FindPodCommandParameter(ctx, client, "component=kube-controller-manager", "--service-cluster-ip-range")
}

func findClusterIPRangeFromServiceCreation(ctx context.Context, client controllerClient.Client) (string, error) {
ns := os.Getenv("WATCH_NAMESPACE")
// WATCH_NAMESPACE env should be set to operator's namespace, if running in operator
Expand Down Expand Up @@ -153,50 +162,23 @@ func parseServiceCIDRFrom(msg string) (string, error) {
}

func findPodIPRange(ctx context.Context, client controllerClient.Client) (string, error) {
podIPRange, err := findPodIPRangeKubeController(ctx, client)
podIPRange, err := findPodIPRangeFromKubeController(ctx, client)
if err != nil || podIPRange != "" {
return podIPRange, err
}

podIPRange, err = findPodIPRangeKubeProxy(ctx, client)
if err != nil || podIPRange != "" {
return podIPRange, err
}

podIPRange, err = findPodIPRangeFromNodeSpec(ctx, client)
podIPRange, err = findPodIPRangeFromKubeProxy(ctx, client)
if err != nil || podIPRange != "" {
return podIPRange, err
}

return "", nil
}

func findPodIPRangeKubeController(ctx context.Context, client controllerClient.Client) (string, error) {
func findPodIPRangeFromKubeController(ctx context.Context, client controllerClient.Client) (string, error) {
return FindPodCommandParameter(ctx, client, "component=kube-controller-manager", "--cluster-cidr")
}

func findPodIPRangeKubeProxy(ctx context.Context, client controllerClient.Client) (string, error) {
return FindPodCommandParameter(ctx, client, "component=kube-proxy", "--cluster-cidr")
}

func findPodIPRangeFromNodeSpec(ctx context.Context, client controllerClient.Client) (string, error) {
nodes := &corev1.NodeList{}

err := client.List(ctx, nodes)
if err != nil {
return "", errors.WithMessagef(err, "error listing nodes")
}

return parseToPodCidr(nodes.Items)
}

func parseToPodCidr(nodes []corev1.Node) (string, error) {
// In K8s, each node is typically assigned a unique PodCIDR range for the pods that run on that node.
// Each node's PodCIDR is used to allocate IP addresses to the pods scheduled on that node. Only if
// the cluster is a single node deployment, we should rely on the node.Spec.PodCIDR as podCIDR of the cluster.
if len(nodes) == 1 {
return nodes[0].Spec.PodCIDR, nil
}

return "", nil
func findPodIPRangeFromKubeProxy(ctx context.Context, client controllerClient.Client) (string, error) {
return FindPodCommandParameter(ctx, client, "k8s-app=kube-proxy", "--cluster-cidr")
}

0 comments on commit 66c3f51

Please sign in to comment.