Skip to content

Commit

Permalink
Address comments
Browse files Browse the repository at this point in the history
  • Loading branch information
claudiubelu committed Dec 3, 2024
1 parent b97b1b2 commit 3b34268
Show file tree
Hide file tree
Showing 8 changed files with 71 additions and 63 deletions.
6 changes: 2 additions & 4 deletions src/k8s/pkg/k8sd/app/hooks_bootstrap.go
Original file line number Diff line number Diff line change
Expand Up @@ -232,13 +232,12 @@ func (a *App) onBootstrapWorkerNode(ctx context.Context, s state.State, encodedT
}

serviceConfigs := types.K8sServiceConfigs{
IsControlPlane: false,
ExtraNodeKubeletArgs: joinConfig.ExtraNodeKubeletArgs,
ExtraNodeKubeProxyArgs: joinConfig.ExtraNodeKubeProxyArgs,
}

// Pre-init checks
if err := snap.PreInitChecks(ctx, cfg, serviceConfigs); err != nil {
if err := snap.PreInitChecks(ctx, cfg, serviceConfigs, false); err != nil {
return fmt.Errorf("pre-init checks failed for worker node: %w", err)
}

Expand Down Expand Up @@ -426,15 +425,14 @@ func (a *App) onBootstrapControlPlane(ctx context.Context, s state.State, bootst
cfg.Certificates.K8sdPrivateKey = utils.Pointer(certificates.K8sdPrivateKey)

serviceConfigs := types.K8sServiceConfigs{
IsControlPlane: true,
ExtraNodeKubeSchedulerArgs: bootstrapConfig.ExtraNodeKubeSchedulerArgs,
ExtraNodeKubeControllerManagerArgs: bootstrapConfig.ExtraNodeKubeControllerManagerArgs,
ExtraNodeKubeletArgs: bootstrapConfig.ExtraNodeKubeletArgs,
ExtraNodeKubeProxyArgs: bootstrapConfig.ExtraNodeKubeProxyArgs,
}

// Pre-init checks
if err := snap.PreInitChecks(ctx, cfg, serviceConfigs); err != nil {
if err := snap.PreInitChecks(ctx, cfg, serviceConfigs, true); err != nil {
return fmt.Errorf("pre-init checks failed for bootstrap node: %w", err)
}

Expand Down
3 changes: 1 addition & 2 deletions src/k8s/pkg/k8sd/app/hooks_join.go
Original file line number Diff line number Diff line change
Expand Up @@ -139,15 +139,14 @@ func (a *App) onPostJoin(ctx context.Context, s state.State, initConfig map[stri
}

serviceConfigs := types.K8sServiceConfigs{
IsControlPlane: true,
ExtraNodeKubeSchedulerArgs: joinConfig.ExtraNodeKubeSchedulerArgs,
ExtraNodeKubeControllerManagerArgs: joinConfig.ExtraNodeKubeControllerManagerArgs,
ExtraNodeKubeletArgs: joinConfig.ExtraNodeKubeletArgs,
ExtraNodeKubeProxyArgs: joinConfig.ExtraNodeKubeProxyArgs,
}

// Pre-init checks
if err := snap.PreInitChecks(ctx, cfg, serviceConfigs); err != nil {
if err := snap.PreInitChecks(ctx, cfg, serviceConfigs, true); err != nil {
return fmt.Errorf("pre-init checks failed for joining node: %w", err)
}

Expand Down
1 change: 0 additions & 1 deletion src/k8s/pkg/k8sd/types/k8s_service_configs.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ const (
)

type K8sServiceConfigs struct {
IsControlPlane bool
ExtraNodeKubeControllerManagerArgs map[string]*string
ExtraNodeKubeSchedulerArgs map[string]*string
ExtraNodeKubeletArgs map[string]*string
Expand Down
2 changes: 1 addition & 1 deletion src/k8s/pkg/snap/interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,5 +66,5 @@ type Snap interface {

K8sdClient(address string) (k8sd.Client, error) // k8sd client

PreInitChecks(ctx context.Context, config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs) error // pre-init checks before k8s-snap can start
PreInitChecks(ctx context.Context, config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs, isControlPlane bool) error // pre-init checks before k8s-snap can start
}
2 changes: 1 addition & 1 deletion src/k8s/pkg/snap/mock/mock.go
Original file line number Diff line number Diff line change
Expand Up @@ -245,7 +245,7 @@ func (s *Snap) SnapctlSet(ctx context.Context, args ...string) error {
return s.SnapctlSetErr
}

func (s *Snap) PreInitChecks(ctx context.Context, config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs) error {
func (s *Snap) PreInitChecks(ctx context.Context, config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs, isControlPlane bool) error {
s.PreInitChecksCalledWith = append(s.PreInitChecksCalledWith, config)
return s.PreInitChecksErr
}
Expand Down
53 changes: 3 additions & 50 deletions src/k8s/pkg/snap/snap.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ import (
"os"
"os/exec"
"path/filepath"
"strconv"
"strings"

"github.com/canonical/k8s/pkg/client/dqlite"
Expand All @@ -19,6 +18,7 @@ import (
"github.com/canonical/k8s/pkg/k8sd/types"
"github.com/canonical/k8s/pkg/log"
"github.com/canonical/k8s/pkg/utils"
"github.com/canonical/k8s/pkg/utils/checks"
"github.com/moby/sys/mountinfo"
"gopkg.in/yaml.v2"
"k8s.io/cli-runtime/pkg/genericclioptions"
Expand Down Expand Up @@ -329,8 +329,8 @@ func (s *snap) SnapctlSet(ctx context.Context, args ...string) error {
return s.runCommand(ctx, append([]string{"snapctl", "set"}, args...))
}

func (s *snap) PreInitChecks(ctx context.Context, config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs) error {
if err := checkK8sServicePorts(config, serviceConfigs); err != nil {
func (s *snap) PreInitChecks(ctx context.Context, config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs, isControlPlane bool) error {
if err := checks.CheckK8sServicePorts(config, serviceConfigs, isControlPlane); err != nil {
return fmt.Errorf("Encountered error(s) while verifying port availability for Kubernetes services: %w", err)
}

Expand All @@ -357,51 +357,4 @@ func (s *snap) PreInitChecks(ctx context.Context, config types.ClusterConfig, se
return nil
}

func checkK8sServicePorts(config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs) error {
var allErrors []error
ports := map[string]string{
// Default values from official Kubernetes documentation.
"kubelet": serviceConfigs.GetKubeletPort(),
"kubelet-healthz": serviceConfigs.GetKubeletHealthzPort(),
"kubelet-read-only": serviceConfigs.GetKubeletReadOnlyPort(),
"k8s-dqlite": strconv.Itoa(config.Datastore.GetK8sDqlitePort()),
"loadbalancer": strconv.Itoa(config.LoadBalancer.GetBGPPeerPort()),
}

if port, err := serviceConfigs.GetKubeProxyHealthzPort(); err != nil {
allErrors = append(allErrors, err)
} else {
ports["kube-proxy-healhz"] = port
}

if port, err := serviceConfigs.GetKubeProxyMetricsPort(); err != nil {
allErrors = append(allErrors, err)
} else {
ports["kube-proxy-metrics"] = port
}

if serviceConfigs.IsControlPlane {
ports["kube-apiserver"] = strconv.Itoa(config.APIServer.GetSecurePort())
ports["kube-scheduler"] = serviceConfigs.GetKubeSchedulerPort()
ports["kube-controller-manager"] = serviceConfigs.GetKubeControllerManagerPort()
} else {
ports["kube-apiserver-proxy"] = strconv.Itoa(config.APIServer.GetSecurePort())
}

for service, port := range ports {
if port == "0" {
// Some ports may be set to 0 in order to disable them. No need to check.
continue
}
if open, err := utils.IsLocalPortOpen(port); err != nil {
// Could not open port due to error.
allErrors = append(allErrors, fmt.Errorf("could not check port %s (needed by: %s): %w", port, service, err))
} else if !open {
allErrors = append(allErrors, fmt.Errorf("port %s (needed by: %s) is already in use.", port, service))
}
}

return errors.Join(allErrors...)
}

var _ Snap = &snap{}
8 changes: 4 additions & 4 deletions src/k8s/pkg/snap/snap_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ func TestSnap(t *testing.T) {
conf := types.ClusterConfig{}
serviceConfigs := types.K8sServiceConfigs{}

err = snap.PreInitChecks(context.Background(), conf, serviceConfigs)
err = snap.PreInitChecks(context.Background(), conf, serviceConfigs, true)
g.Expect(err).To(Not(HaveOccurred()))
expectedCalls := []string{}
for _, binary := range []string{"kube-apiserver", "kube-controller-manager", "kube-scheduler", "kube-proxy", "kubelet"} {
Expand All @@ -163,7 +163,7 @@ func TestSnap(t *testing.T) {
g.Expect(err).To(Not(HaveOccurred()))
defer l.Close()

err = snap.PreInitChecks(context.Background(), conf, serviceConfigs)
err = snap.PreInitChecks(context.Background(), conf, serviceConfigs, true)
g.Expect(err).To(HaveOccurred())
})

Expand All @@ -177,15 +177,15 @@ func TestSnap(t *testing.T) {
f.Close()
defer os.Remove(f.Name())

err = snap.PreInitChecks(context.Background(), conf, serviceConfigs)
err = snap.PreInitChecks(context.Background(), conf, serviceConfigs, true)
g.Expect(err).To(HaveOccurred())
})

t.Run("Fail run command", func(t *testing.T) {
g := NewWithT(t)
mockRunner.Err = fmt.Errorf("some error")

err := snap.PreInitChecks(context.Background(), conf, serviceConfigs)
err := snap.PreInitChecks(context.Background(), conf, serviceConfigs, true)
g.Expect(err).To(HaveOccurred())
})
})
Expand Down
59 changes: 59 additions & 0 deletions src/k8s/pkg/utils/checks/checks.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
package checks

import (
"errors"
"fmt"
"strconv"

"github.com/canonical/k8s/pkg/k8sd/types"
"github.com/canonical/k8s/pkg/utils"
)

// CheckK8sServicePorts verifies that the Kubernetes-related ports are free to be used.
// The ports checked depends on whether a node is a control plane node, or a worker node.
func CheckK8sServicePorts(config types.ClusterConfig, serviceConfigs types.K8sServiceConfigs, isControlPlane bool) error {
var allErrors []error
ports := map[string]string{
// Default values from official Kubernetes documentation.
"kubelet": serviceConfigs.GetKubeletPort(),
"kubelet-healthz": serviceConfigs.GetKubeletHealthzPort(),
"kubelet-read-only": serviceConfigs.GetKubeletReadOnlyPort(),
"k8s-dqlite": strconv.Itoa(config.Datastore.GetK8sDqlitePort()),
"loadbalancer": strconv.Itoa(config.LoadBalancer.GetBGPPeerPort()),
}

if port, err := serviceConfigs.GetKubeProxyHealthzPort(); err != nil {
allErrors = append(allErrors, err)
} else {
ports["kube-proxy-healhz"] = port
}

if port, err := serviceConfigs.GetKubeProxyMetricsPort(); err != nil {
allErrors = append(allErrors, err)
} else {
ports["kube-proxy-metrics"] = port
}

if isControlPlane {
ports["kube-apiserver"] = strconv.Itoa(config.APIServer.GetSecurePort())
ports["kube-scheduler"] = serviceConfigs.GetKubeSchedulerPort()
ports["kube-controller-manager"] = serviceConfigs.GetKubeControllerManagerPort()
} else {
ports["kube-apiserver-proxy"] = strconv.Itoa(config.APIServer.GetSecurePort())
}

for service, port := range ports {
if port == "0" {
// Some ports may be set to 0 in order to disable them. No need to check.
continue
}
if open, err := utils.IsLocalPortOpen(port); err != nil {
// Could not open port due to error.
allErrors = append(allErrors, fmt.Errorf("could not check port %s (needed by: %s): %w", port, service, err))
} else if !open {
allErrors = append(allErrors, fmt.Errorf("port %s (needed by: %s) is already in use.", port, service))
}
}

return errors.Join(allErrors...)
}

0 comments on commit 3b34268

Please sign in to comment.