写一个给集群中的node大label

背景:

集群中的ds相关的服务,需要指定label的部署

package main

import (
	"bytes"
	"log"
	"os"
	"os/exec"
	"path/filepath"
	"strings"
	"time"
)

const logFilePath = "test.log"

func GetTargetIP(config string) []string {
	cmd := exec.Command("kubectl", "--kubeconfig", config, "get", "nodes", "--selector=!container-runtime=containerd", "--selector=!ds-schedulable")
	var outBuffer bytes.Buffer
	cmd.Stdout = &outBuffer
	cmd.Stderr = os.Stderr

	err := cmd.Run()
	if err != nil {
		log.Fatalf("Error executing kubectl command: %v", err)
		return []string{} // 返回一个空切片表示错误
	}

	dataips := []string{}
	// 命令成功执行,继续处理输出
	out := strings.TrimSpace(outBuffer.String())
	ips := strings.Split(out, "\n")
	for _, data := range ips {
		if !strings.Contains(data, "NAME") {
			lines := strings.Split(data, "\n")
			for _, line := range lines {
				fileds := strings.Fields(line)
				if len(fileds) > 0 {
					dataips = append(dataips, fileds[0])
				}
			}
		}
	}
	return dataips
}

func LabelsIp(config string, ip string) {
	cmd := exec.Command("kubectl", "--kubeconfig", config, "label", "node", ip, "ds-schedulable=", "container-runtime=containerd", "--overwrite")
	var outBuffer bytes.Buffer
	cmd.Stdout = &outBuffer
	cmd.Stderr = os.Stderr
	err := cmd.Run()
	if err != nil {
		log.Fatalf("Error executing kubectl command: %v", err)
	} else {
		log.Printf("lable success ip: %s", ip)
	}
}

// 获取目录下的所有文件名
func getFilesInDirectory(directoryPath string) ([]string, error) {
	var fileNames []string

	// 使用 filepath.Walk 遍历目录
	err := filepath.Walk(directoryPath, func(path string, info os.FileInfo, err error) error {
		if err != nil {
			return err
		}

		// 忽略目录本身
		if path != directoryPath {
			// 获取文件或目录的相对路径
			relativePath, _ := filepath.Rel(directoryPath, path)
			fileNames = append(fileNames, relativePath)
		}

		return nil
	})

	if err != nil {
		return nil, err
	}

	return fileNames, nil
}

func crontab() {
	logFile, err := os.OpenFile(logFilePath, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
	if err != nil {
		log.Fatalf("Error opening log file: %v", err)
	}
	defer logFile.Close()

	directoryPath := "/home/sunlixin/go/feed-node/config"
	fileNames, err := getFilesInDirectory(directoryPath)
	log.Println(fileNames)
	// fmt.Println(fileNames)
	if err != nil {
		log.Fatalf("Error getting files in directory: %v", err)
	}
	for _, fileName := range fileNames {
        // fmt.Println(fileName)
		configpath := directoryPath + "/" + fileName
		targetIPs := GetTargetIP(configpath)
		// fmt.Println(len(targetIPs))
		log.Printf("cluster:%s,num:%d", fileName, len(targetIPs))
		for _, ip := range targetIPs {
			LabelsIp(configpath, ip)
		}
	}
}

func main(){
	interval := 10 * time.Minute
	ticker := time.NewTicker(interval)
	defer ticker.Stop()
	for {
		select {
		case <-ticker.C:
			crontab()
		}
	}
}

 

posted @ 2024-03-10 23:11  百因必有果  阅读(6)  评论(0编辑  收藏  举报