From b8affb05bc7436515abb4e6933553176c45ace59 Mon Sep 17 00:00:00 2001 From: sealos-ci-robot <109538726+sealos-ci-robot@users.noreply.github.com> Date: Wed, 11 Oct 2023 22:22:50 +0800 Subject: [PATCH] refactor env keys (#4066) (#4076) * feat: add SYNC_WORKDIR env key * refactor: remove SEALOS_SCP_CHECKSUM env key --------- Signed-off-by: fengxsong Co-authored-by: fengxsong --- .../applydrivers/apply_drivers_default.go | 18 ++++++- pkg/ssh/scp.go | 49 +------------------ pkg/system/env.go | 12 ++--- 3 files changed, 23 insertions(+), 56 deletions(-) diff --git a/pkg/apply/applydrivers/apply_drivers_default.go b/pkg/apply/applydrivers/apply_drivers_default.go index c2158075ea6..e620a419975 100644 --- a/pkg/apply/applydrivers/apply_drivers_default.go +++ b/pkg/apply/applydrivers/apply_drivers_default.go @@ -19,6 +19,7 @@ import ( "errors" "fmt" "os" + "strconv" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/version" @@ -31,6 +32,7 @@ import ( "github.com/labring/sealos/pkg/constants" "github.com/labring/sealos/pkg/exec" "github.com/labring/sealos/pkg/ssh" + "github.com/labring/sealos/pkg/system" v2 "github.com/labring/sealos/pkg/types/v1beta1" "github.com/labring/sealos/pkg/utils/confirm" "github.com/labring/sealos/pkg/utils/iputils" @@ -273,6 +275,12 @@ func (c *Applier) deleteCluster() error { } func (c *Applier) syncWorkdir() { + if v, _ := system.Get(system.SyncWorkDirEnvKey); v != "" { + vb, _ := strconv.ParseBool(v) + if !vb { + return + } + } workDir := constants.ClusterDir(c.ClusterDesired.Name) logger.Debug("sync workdir: %s", workDir) ipList := c.ClusterDesired.GetMasterIPAndPortList() @@ -295,8 +303,14 @@ func (c *Applier) syncWorkdir() { // save cluster to file after apply func (c *Applier) saveClusterFile() { clusterPath := constants.Clusterfile(c.ClusterDesired.Name) - logger.Debug("save objects into local: %s, objects: %v", clusterPath, c.getWriteBackObjects()) - saveErr := yaml.MarshalFile(clusterPath, c.getWriteBackObjects()...) + objects := c.getWriteBackObjects() + if logger.IsDebugMode() { + out, err := yaml.MarshalConfigs(objects...) + if err == nil { + logger.Debug("save objects into local: %s, objects: %s", clusterPath, string(out)) + } + } + saveErr := yaml.MarshalFile(clusterPath, objects...) if saveErr != nil { logger.Error("failed to serialize into file: %s error, %s", clusterPath, saveErr) } diff --git a/pkg/ssh/scp.go b/pkg/ssh/scp.go index bbbf90e5ea2..4c6af22e4c5 100644 --- a/pkg/ssh/scp.go +++ b/pkg/ssh/scp.go @@ -20,18 +20,14 @@ import ( "os" "path" "path/filepath" - "strconv" "strings" "time" - "github.com/labring/sealos/pkg/system" - "github.com/pkg/sftp" "github.com/schollz/progressbar/v3" "golang.org/x/crypto/ssh" "github.com/labring/sealos/pkg/utils/file" - "github.com/labring/sealos/pkg/utils/hash" "github.com/labring/sealos/pkg/utils/logger" "github.com/labring/sealos/pkg/utils/progress" ) @@ -198,20 +194,6 @@ func (c *Client) doCopy(client *sftp.Client, host, src, dest string, epu *progre } } } else { - fn := func(host string, name string) bool { - exists, err := checkIfRemoteFileExists(client, name) - if err != nil { - logger.Error("failed to detect remote file exists: %v", err) - } - return exists - } - if isCheckFileMD5() && fn(host, dest) { - rfp, _ := client.Stat(dest) - if lfp.Size() == rfp.Size() && hash.FileDigest(src) == c.RemoteSha256Sum(host, dest) { - logger.Debug("remote dst %s already exists and is the latest version, skip copying process", dest) - return nil - } - } lf, err := os.Open(filepath.Clean(src)) if err != nil { return fmt.Errorf("failed to open: %v", err) @@ -240,37 +222,8 @@ func (c *Client) doCopy(client *sftp.Client, host, src, dest string, epu *progre if err = client.PosixRename(destTmp, dest); err != nil { return fmt.Errorf("failed to rename %s to %s: %v", destTmp, dest, err) } - if isCheckFileMD5() { - dh := c.RemoteSha256Sum(host, dest) - if dh == "" { - // when ssh connection failed, remote sha256 is default to "", so ignore it. - return nil - } - sh := hash.FileDigest(src) - if sh != dh { - return fmt.Errorf("sha256 sum not match %s(%s) != %s(%s), maybe network corruption?", src, sh, dest, dh) - } - } + _ = epu.Add(1) } return nil } - -func checkIfRemoteFileExists(client *sftp.Client, fp string) (bool, error) { - _, err := client.Stat(fp) - if err != nil { - if os.IsNotExist(err) { - return false, nil - } - return false, err - } - return true, nil -} - -func isCheckFileMD5() bool { - if v, err := system.Get(system.ScpChecksumConfigKey); err == nil { - boolVal, _ := strconv.ParseBool(v) - return boolVal - } - return true -} diff --git a/pkg/system/env.go b/pkg/system/env.go index f3825ce1cec..975c3bee150 100644 --- a/pkg/system/env.go +++ b/pkg/system/env.go @@ -82,16 +82,16 @@ var configOptions = []ConfigOption{ Description: `the log level to be used in buildah modules, either "trace", "debug", "info", "warn", "error", "fatal", or "panic".`, OSEnv: BuildahLogLevelConfigKey, }, - { - Key: ScpChecksumConfigKey, - Description: "whether to check the md5sum value is consistent during the copy process.", - DefaultValue: "false", - }, { Key: ContainerStorageConfEnvKey, Description: "path of container storage config file, setting this env will override the default location", OSEnv: ContainerStorageConfEnvKey, }, + { + Key: SyncWorkDirEnvKey, + Description: "whether to sync runtime root dir to all master nodes for backup purpose", + DefaultValue: "true", + }, } const ( @@ -101,7 +101,7 @@ const ( BuildahFormatConfigKey = "BUILDAH_FORMAT" BuildahLogLevelConfigKey = "BUILDAH_LOG_LEVEL" ContainerStorageConfEnvKey = "CONTAINERS_STORAGE_CONF" - ScpChecksumConfigKey = "SCP_CHECKSUM" + SyncWorkDirEnvKey = "SYNC_WORKDIR" ) func (*envSystemConfig) getValueOrDefault(key string) (*ConfigOption, error) {