From 3e84ce972f45edc12b49e2cd3ab4635bb717321d Mon Sep 17 00:00:00 2001 From: liuxiaolong <736321739@qq.com> Date: 星期五, 20 十二月 2019 11:03:54 +0800 Subject: [PATCH] fix bak --- service/SysService.go | 40 +++++++++++++++++++++++++++++++++++++++- 1 files changed, 39 insertions(+), 1 deletions(-) diff --git a/service/SysService.go b/service/SysService.go index c50339f..9fa1619 100644 --- a/service/SysService.go +++ b/service/SysService.go @@ -152,6 +152,9 @@ //upgrade func (sv SysService) Upgrade(identifier string,filename string) (bool,error) { + if !bakBeforeUpgrade() { + return false,errors.New("鏇存柊鍓嶅浠藉け璐�") + } configPatchPath := "" if config.Server.PatchPath != "" { configPatchPath = config.Server.PatchPath @@ -189,6 +192,30 @@ } } +func bakBeforeUpgrade() bool { + configBakPath := "" + if config.Server.BakPath != "" { + configBakPath = config.Server.BakPath + } else { + configBakPath = "/opt/vasystem/bak" + } + if util.Exists(configBakPath) { + //鍙繚鐣欐渶鏂扮殑鐗堟湰 + if err := os.RemoveAll(configBakPath);err != nil { + return false + } + } + if !util.CreateDirectory(configBakPath) { + return false + } + b, err := ExecCmd("cp -r /opt/vasystem/bin /opt/vasystem/bak") + if err != nil { + logger.Debug("bakBeforeUpgrade result:",string(b),"err:",err) + return false + } + return true +} + //鏇存柊绯荤粺绋嬪簭 func updatePatch(identifier string, ext string) bool { configPatchPath := "" @@ -216,9 +243,14 @@ logger.Debug("UnZip err:",err,"zipFile:",zipFilePath) return false } + //鍒ゆ柇鏇存柊鍖呴噷鏄惁鏈夎ˉ涓佽剼鏈紝濡傛灉鏈夊垯鎵ц锛屽惁鍒欐墽琛寀pdatePatch.sh + updateCmd := fmt.Sprintf("./updatePatch.sh %s %s %s &",unZipPath,zipFilePath,configPatchPath+"/"+identifier) + if util.Exists(unZipPath+"upgrade.sh") { + updateCmd = fmt.Sprintf("%supgrade.sh %s %s %s &",unZipPath,unZipPath,zipFilePath,configPatchPath+"/"+identifier) + logger.Debug("upgrade use ",unZipPath,"upgrade.sh") + } //2.鏇存柊绯荤粺 var cmd *exec.Cmd - updateCmd := fmt.Sprintf("./updatePatch.sh %s %s %s &",unZipPath,zipFilePath,configPatchPath+"/"+identifier) cmd = exec.Command("/bin/sh","-c", updateCmd) if b, err := cmd.Output(); err != nil { logger.Debug("updatePatch err:",err,"result:",string(b)) @@ -239,4 +271,10 @@ logger.Debug("mergeChunks result:",string(b),"cmd: ./mergeAll.sh ", chunkPath, storePath) return true } +} + +func ExecCmd(cmdStr string) ([]byte,error) { + var cmd *exec.Cmd + cmd = exec.Command("/bin/sh", "-c",cmdStr) + return cmd.Output() } \ No newline at end of file -- Gitblit v1.8.0