Skip to content

Commit

Permalink
Add NodeLocalDNS configuration to the kubenest workflow.
Browse files Browse the repository at this point in the history
Signed-off-by: luoyuanze <[email protected]>
  • Loading branch information
lyzuiui committed Dec 31, 2024
1 parent a2b1928 commit 69a2f9e
Show file tree
Hide file tree
Showing 8 changed files with 74 additions and 6 deletions.
6 changes: 6 additions & 0 deletions deploy/crds/kosmos.io_kubenestconfigurations.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,9 @@ spec:
type: string
etcdUnitSize:
type: string
externalPort:
format: int32
type: integer
forceDestroy:
description: todo Group according to the parameters of apiserver,
etcd, coredns, etc. ForceDestroy indicates whether to force destroy
Expand All @@ -77,6 +80,9 @@ spec:
type: string
type: array
type: object
useNodeLocalDNS:
default: false
type: boolean
useTenantDNS:
default: false
type: boolean
Expand Down
5 changes: 4 additions & 1 deletion deploy/crds/kosmos.io_virtualclusters.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -75,8 +75,8 @@ spec:
etcdUnitSize:
type: string
externalPort:
type: integer
format: int32
type: integer
forceDestroy:
description: todo Group according to the parameters of apiserver,
etcd, coredns, etc. ForceDestroy indicates whether to force
Expand All @@ -98,6 +98,9 @@ spec:
type: string
type: array
type: object
useNodeLocalDNS:
default: false
type: boolean
useTenantDNS:
default: false
type: boolean
Expand Down
10 changes: 9 additions & 1 deletion hack/k8s-in-k8s/kubelet_node_helper.sh
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ LOG_NAME=${2:-kubelet}
JOIN_HOST=$2
JOIN_TOKEN=$3
JOIN_CA_HASH=$4
NODE_LOCAL_DNS_ADDRESS=$3

function unjoin() {
# before unjoin, you need delete node by kubectl
Expand Down Expand Up @@ -248,7 +249,14 @@ function join() {
exit 1
fi
echo "exec(4/8): set core dns address...."
sed -e "s|__DNS_ADDRESS__|$DNS_ADDRESS|g" -e "w ${PATH_KUBELET_CONF}/${KUBELET_CONFIG_NAME}" "$PATH_FILE_TMP"/"$KUBELET_CONFIG_NAME"
if [ -n "$NODE_LOCAL_DNS_ADDRESS" ]; then
sed -e "/__DNS_ADDRESS__/i - ${NODE_LOCAL_DNS_ADDRESS}" \
-e "s|__DNS_ADDRESS__|${DNS_ADDRESS}|g" \
"$PATH_FILE_TMP/$KUBELET_CONFIG_NAME" \
> "${PATH_KUBELET_CONF}/${KUBELET_CONFIG_NAME}"
else
sed -e "s|__DNS_ADDRESS__|$DNS_ADDRESS|g" -e "w ${PATH_KUBELET_CONF}/${KUBELET_CONFIG_NAME}" "$PATH_FILE_TMP"/"$KUBELET_CONFIG_NAME"
fi
if [ $? -ne 0 ]; then
exit 1
fi
Expand Down
3 changes: 3 additions & 0 deletions pkg/apis/kosmos/v1alpha1/kubenestconfiguration_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,9 @@ type KubeInKubeConfig struct {
UseTenantDNS bool `yaml:"useTenantDNS" json:"useTenantDNS,omitempty"`
// +optional
ExternalPort int32 `json:"externalPort,omitempty"`
// +kubebuilder:default=false
// +optional
UseNodeLocalDNS bool `yaml:"useNodeLocalDNS" json:"useNodeLocalDNS,omitempty"`
}

// TenantEntrypoint contains the configuration for the tenant entrypoint.
Expand Down
6 changes: 6 additions & 0 deletions pkg/generated/openapi/zz_generated.openapi.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions pkg/kubenest/constants/constant.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,12 @@ const (

//in virtual cluster
APIServerExternalService = "api-server-external-service"

//nodelocaldns
NodeLocalDNSComponentName = "virtual-node-local-dns"
NodeLocalDNSIp = "169.254.20.10"
NodeLocalDNSClusterDomain = "cluster.local"
NodeLocalDNSService = "__PILLAR__DNS__SERVER__"
)

type Action string
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -254,9 +254,12 @@ func NewRemoteNodeJoinTask() Task {
Retry: true,
Run: func(ctx context.Context, to TaskOpt, _ interface{}) (interface{}, error) {
exectHelper := exector.NewExectorHelper(to.NodeInfo.Spec.NodeIP, "")

baseCmd := fmt.Sprintf("bash %s join %s", env.GetExectorShellName(), to.KubeDNSAddress)
if to.VirtualCluster.Spec.KubeInKubeConfig != nil && to.VirtualCluster.Spec.KubeInKubeConfig.UseNodeLocalDNS {
baseCmd = fmt.Sprintf("bash %s join %s %s", env.GetExectorShellName(), to.KubeDNSAddress, constants.NodeLocalDNSIp)
}
joinCmd := &exector.CMDExector{
Cmd: fmt.Sprintf("bash %s join %s", env.GetExectorShellName(), to.KubeDNSAddress),
Cmd: baseCmd,
}
to.Loger().Infof("join node %s with cmd: %s", to.NodeInfo.Name, joinCmd.Cmd)
ret := exectHelper.DoExector(ctx.Done(), joinCmd)
Expand Down
37 changes: 35 additions & 2 deletions pkg/kubenest/tasks/manifests_components.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,9 @@ package tasks

import (
"context"
"fmt"
"os"
"path/filepath"

"github.com/pkg/errors"
corev1 "k8s.io/api/core/v1"
apierrors "k8s.io/apimachinery/pkg/api/errors"
"k8s.io/apimachinery/pkg/api/meta"
Expand All @@ -15,13 +14,16 @@ import (
"k8s.io/apimachinery/pkg/util/yaml"
"k8s.io/client-go/dynamic"
clientset "k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
"k8s.io/client-go/tools/clientcmd"
"k8s.io/klog/v2"
"path/filepath"

"github.com/kosmos.io/kosmos/pkg/kubenest/constants"
"github.com/kosmos.io/kosmos/pkg/kubenest/util"
apiclient "github.com/kosmos.io/kosmos/pkg/kubenest/util/api-client"
"github.com/kosmos.io/kosmos/pkg/kubenest/workflow"
"github.com/pkg/errors"
)

type ComponentConfig struct {
Expand Down Expand Up @@ -91,10 +93,22 @@ func applyComponentsManifests(r workflow.RunData) error {
return err
}

kubeDNSIP, err := getKubeDNSClusterIP(config)
if err != nil {
return errors.Wrap(err, "Failed to get kube-dns ClusterIP")
}
klog.Infof("kube-dns CLUSTER-IP: %s", kubeDNSIP)

templatedMapping := make(map[string]interface{}, 2)
templatedMapping["KUBE_PROXY_KUBECONFIG"] = string(secret.Data[constants.KubeConfig])
imageRepository, _ := util.GetImageMessage()
templatedMapping["ImageRepository"] = imageRepository

templatedMapping["PillarLocalDNS"] = constants.NodeLocalDNSIp
templatedMapping["PillarDNSDomain"] = constants.NodeLocalDNSClusterDomain
templatedMapping["PillarClusterDNS"] = kubeDNSIP
templatedMapping["PillarDNSServer"] = ""

for k, v := range data.PluginOptions() {
templatedMapping[k] = v
}
Expand All @@ -111,6 +125,7 @@ func applyComponentsManifests(r workflow.RunData) error {
}

UseTenantDNS := data.VirtualCluster().Spec.KubeInKubeConfig != nil && data.VirtualCluster().Spec.KubeInKubeConfig.UseTenantDNS
UseNodeLocalDNS := data.VirtualCluster().Spec.KubeInKubeConfig != nil && data.VirtualCluster().Spec.KubeInKubeConfig.UseNodeLocalDNS

skipComponents := getSkipComponentsForVirtualCluster([]*SkipComponentCondition{
{
Expand All @@ -122,6 +137,11 @@ func applyComponentsManifests(r workflow.RunData) error {
Condition: !keepalivedEnable,
ComponentName: constants.VipKeepalivedComponentName,
},
{
// skip nodelocaldns component if nodelocaldns is not enabled
Condition: !UseNodeLocalDNS,
ComponentName: constants.NodeLocalDNSComponentName,
},
})

for _, component := range components {
Expand Down Expand Up @@ -215,3 +235,16 @@ func applyTemplatedManifests(component string, dynamicClient dynamic.Interface,
}
return nil
}
func getKubeDNSClusterIP(config *rest.Config) (string, error) {
client, err := clientset.NewForConfig(config)
if err != nil {
return "", fmt.Errorf("failed to create kubernetes client: %v", err)
}

svc, err := client.CoreV1().Services("kube-system").Get(context.TODO(), "kube-dns", metav1.GetOptions{})
if err != nil {
return "", fmt.Errorf("failed to get kube-dns service: %v", err)
}

return svc.Spec.ClusterIP, nil
}

0 comments on commit 69a2f9e

Please sign in to comment.