Skip to content

Commit

Permalink
fix: join cluster
Browse files Browse the repository at this point in the history
Signed-off-by: Bob <[email protected]>
  • Loading branch information
Qaplagzy committed Jun 7, 2024
1 parent 38012ba commit 3771259
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 14 deletions.
10 changes: 7 additions & 3 deletions pkg/build/edgeimage/internal/kube/source.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ import (
// this is used by FindSource
const ImportPath = "kubeedge"

// FindSource attempts to locate a KubeEdge checkout using go's build package
func FindSource() (root string, err error) {
// look up the source the way go build would
pkg, err := build.Default.Import(ImportPath, build.Default.GOPATH, build.FindOnly|build.IgnoreVendor)
Expand All @@ -44,6 +45,8 @@ func FindSource() (root string, err error) {
return "", errors.New("could not find kubeedge source")
}

// maybeKubeDir returns true if the dir looks plausibly like a kubernetes
// source directory
func maybeKubeDir(dir string) bool {
// TODO(bentheelder): consider adding other sanity checks
// check if 'go.mod' exists in the directory
Expand All @@ -60,18 +63,19 @@ func findOrCloneKubeEdge(importPath string) (string, error) {
return filepath.Dir(pkg[0].GoFiles[0]), nil
}

branch := "release-1.17"
localDir := filepath.Join(build.Default.GOPATH, "src", importPath)
fmt.Println("Cloning KubeEdge from GitHub to", localDir)

if err := gitClone("https://github.com/kubeedge/kubeedge.git", localDir); err != nil {
if err := gitClone("https://github.com/kubeedge/kubeedge.git", branch, localDir); err != nil {
return "", err
}

return localDir, nil
}

func gitClone(repoURL, localDir string) error {
cmd := exec.Command("git", "clone", repoURL, localDir)
func gitClone(repoURL, branch, localDir string) error {
cmd := exec.Command("git", "clone", "--branch", branch, repoURL, localDir)
if err := cmd.Run(); err != nil {
return fmt.Errorf("failed to clone KubeEdge repository: %w", err)
}
Expand Down
36 changes: 25 additions & 11 deletions pkg/cluster/internal/create/actions/kubeedge/kubeedge.go
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ func (a *Action) startCloudcoreWithKeadm(ctx *actions.ActionContext, node nodes.
// cloudcore svc use NodePort type, to enable edgecore connect to cloudcore, we may add the below routes on the host
//iptables -t nat -A PREROUTING -d ${advertise-address} -p tcp --dport 10000 -j DNAT --to-destination ${NODE_IP}:30000
//iptables -t nat -A PREROUTING -d ${advertise-address} -p tcp --dport 10002 -j DNAT --to-destination ${NODE_IP}:30002
startCmd := fmt.Sprintf("keadm init --advertise-address=%s --profile version=v1.17.0 --kube-config /etc/kubernetes/admin.conf --set cloudCore.hostNetWork=false", a.AdvertiseAddress)
startCmd := fmt.Sprintf("keadm init --advertise-address=%s --profile version=v1.12.0 --kube-config /etc/kubernetes/admin.conf --set cloudCore.hostNetWork=false", a.AdvertiseAddress)
cmd := node.Command("bash", "-c", startCmd)
lines, err := exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
Expand Down Expand Up @@ -326,31 +326,39 @@ func (a *Action) runStartEdgecore(ctx *actions.ActionContext, node nodes.Node) e
return fmt.Errorf("failed to generate cloudcore config: %v", err)
}

cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|token: .*|token: %s|g" /etc/kubeedge/config/edgecore.yaml`, KubeEdgeToken))
cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "/metaServer:/{n;n;s/false/true/;}" /etc/kubeedge/config/edgecore.yaml`))
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
if err != nil {
return fmt.Errorf("failed to modify token: %v", err)
return fmt.Errorf("failed to modify metaServer: %v", err)
}

// modify runtime to containerd
cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|remoteImageEndpoint: .*|remoteImageEndpoint: %s|g" /etc/kubeedge/config/edgecore.yaml`, "unix:///var/run/containerd/containerd.sock"))
cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|runtimeType: .*|runtimeType: remote|g" /etc/kubeedge/config/edgecore.yaml`))
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
if err != nil {
return fmt.Errorf("failed to modify remoteImageEndpoint: %v", err)
return fmt.Errorf("failed to modify runtimeType: %v", err)
}
cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|remoteRuntimeEndpoint: .*|remoteRuntimeEndpoint: %s|g" /etc/kubeedge/config/edgecore.yaml`, "unix:///var/run/containerd/containerd.sock"))

cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|cgroupDriver: .*|cgroupDriver: systemd|g" /etc/kubeedge/config/edgecore.yaml`))
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
if err != nil {
return fmt.Errorf("failed to modify remoteRuntimeEndpoint: %v", err)
return fmt.Errorf("failed to modify cgroupDriver: %v", err)
}
cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|containerRuntime: .*|containerRuntime: %s|g" /etc/kubeedge/config/edgecore.yaml`, "remote"))

cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|imageServiceEndpoint: .*|imageServiceEndpoint: %s|g" /etc/kubeedge/config/edgecore.yaml`, "unix:///var/run/containerd/containerd.sock"))
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
if err != nil {
return fmt.Errorf("failed to modify containerRuntime to remote: %v", err)
return fmt.Errorf("failed to modify imageServiceEndpoint to remote: %v", err)
}

cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|containerRuntimeEndpoint: .*|containerRuntimeEndpoint: %s|g" /etc/kubeedge/config/edgecore.yaml`, "unix:///var/run/containerd/containerd.sock"))
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
if err != nil {
return fmt.Errorf("failed to modify containerRuntimeEndpoint to remote: %v", err)
}

// modify edgeHub.httpServer websocker.server ip cloudcore ip or control-plane ip
Expand Down Expand Up @@ -381,6 +389,12 @@ func (a *Action) runStartEdgecore(ctx *actions.ActionContext, node nodes.Node) e
return fmt.Errorf("failed to modify resolv: %v", err)
}

cmd = node.Command("bash", "-c", fmt.Sprintf(`sed -i -e "s|token: .*|token: %s|g" /etc/kubeedge/config/edgecore.yaml`, KubeEdgeToken))
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
if err != nil {
return fmt.Errorf("failed to modify token: %v", err)
}
cmd = node.Command("bash", "-c", "systemctl daemon-reload && systemctl enable edgecore && systemctl start edgecore")
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
Expand Down Expand Up @@ -408,7 +422,7 @@ func (a *Action) runStartEdgecoreWithKeadm(ctx *actions.ActionContext, node node
// not start MQTT conainer, error: E0728 01:07:37.717267 1429 remote_runtime.go:116] "RunPodSandbox from runtime service failed" err="rpc error: code = Unknown
// desc = failed to reserve sandbox name \"mqtt___0\": name \"mqtt___0\" is reserved for \"264c9ad4f0be7271711a21b0c89f958da582e1869a3b18fb07dd719b16989595\""
// TODO: debug why edgecore segmentfault with nothing
joinCmd := fmt.Sprintf("keadm join --cloudcore-ipport %s --certport 30002 --token %s --remote-runtime-endpoint unix:///var/run/containerd/containerd.sock --runtimetype remote --with-mqtt=false", controlPlaneIP+":30000", KubeEdgeToken)
joinCmd := fmt.Sprintf("keadm join --cgroupdriver=systemd --cloudcore-ipport=%s --token=%s --remote-runtime-endpoint=unix:///var/run/containerd/containerd.sock", controlPlaneIP+":10000", KubeEdgeToken)
cmd = node.Command("bash", "-c", joinCmd)
lines, err = exec.CombinedOutputLines(cmd)
ctx.Logger.V(3).Info(strings.Join(lines, "\n"))
Expand Down

0 comments on commit 3771259

Please sign in to comment.