From 17bd0564775dd89a9e7f9dafb44624b05866714d Mon Sep 17 00:00:00 2001 From: liuxiaolong <736321739@qq.com> Date: 星期五, 20 十二月 2019 18:31:36 +0800 Subject: [PATCH] upgrade use tar.gz --- extend/util/util.go | 58 +++++++++++++++++++++++++++++ service/SysService.go | 22 +++++----- 2 files changed, 69 insertions(+), 11 deletions(-) diff --git a/extend/util/util.go b/extend/util/util.go index 89fc165..9ff0e64 100644 --- a/extend/util/util.go +++ b/extend/util/util.go @@ -1,8 +1,11 @@ package util import ( + "archive/tar" "archive/zip" + "basic.com/valib/logger.git" "bytes" + "compress/gzip" "crypto/md5" "encoding/hex" "encoding/json" @@ -300,6 +303,61 @@ return nil } +func TarGzCheck(filePath string) bool { + f, err := os.Open(filePath) + if err != nil { + return false + } + defer f.Close() + buf := make([]byte, 4) + if n, err := f.Read(buf); err != nil || n < 4 { + return false + } + fType := hex.EncodeToString(buf) + logger.Debug("file type :",fType) + return fType == "8b1f" +} + +//瑙e帇 tar.gz +func DeCompress(tarFile, dest string) error { + srcFile, err := os.Open(tarFile) + if err != nil { + return err + } + defer srcFile.Close() + gr, err := gzip.NewReader(srcFile) + if err != nil { + return err + } + defer gr.Close() + tr := tar.NewReader(gr) + for { + hdr, err := tr.Next() + if err != nil { + if err == io.EOF { + break + } else { + return err + } + } + filename := dest + hdr.Name + file, err := createFile(filename) + if err != nil { + return err + } + io.Copy(file, tr) + } + return nil +} + +func createFile(name string) (*os.File, error) { + err := os.MkdirAll(string([]rune(name)[0:strings.LastIndex(name, "/")]), 0755) + if err != nil { + return nil, err + } + return os.Create(name) +} + func FormatNum(oNum int,n int) string { m := 0 for { diff --git a/service/SysService.go b/service/SysService.go index ab26ee4..02f67b5 100644 --- a/service/SysService.go +++ b/service/SysService.go @@ -177,7 +177,7 @@ return false,errors.New("鑾峰彇鍗囩骇鍘嬬缉鍖卪d5澶辫触") } if strMd5 == identifier { - if util.ZipCheck(zipFilePath) { + if util.TarGzCheck(zipFilePath) { if !updatePatch(identifier, ext) { return false,errors.New("鎵ц鍗囩骇杩囩▼寮傚父") } @@ -228,28 +228,28 @@ configPatchPath = "/opt/vasystem/patch" } //1.瑙e帇缂╂洿鏂板寘 - unZipPath := configPatchPath+"/"+identifier+"_basic/" - if util.Exists(unZipPath) { + unPackPath := configPatchPath+"/"+identifier+"_basic/" + if util.Exists(unPackPath) { //姝ょ増鏈凡缁忔洿鏂拌繃 - rmErr := os.RemoveAll(unZipPath) + rmErr := os.RemoveAll(unPackPath) if rmErr !=nil { return false } } - if !util.CreateDirectory(unZipPath) { + if !util.CreateDirectory(unPackPath) { return false } zipFilePath := configPatchPath+"/"+identifier+ext - err := util.UnZip(zipFilePath, unZipPath) + err := util.DeCompress(zipFilePath, unPackPath) if err !=nil { logger.Debug("UnZip err:",err,"zipFile:",zipFilePath) return false } //濡傛灉閫氱敤鑴氭湰鏈夋洿鏂帮紝鍒欐洿鏂伴�氱敤鑴氭湰 - if util.Exists(unZipPath+"updatePatch.sh") { - cpStr := fmt.Sprintf("cp %s /opt/vasystem/bin",unZipPath+"updatePatch.sh") + if util.Exists(unPackPath+"updatePatch.sh") { + cpStr := fmt.Sprintf("cp %s /opt/vasystem/bin",unPackPath+"updatePatch.sh") b, err := ExecCmd(cpStr) if err != nil { logger.Debug("cp updatePatch.sh to bin err:",err,"result:",string(b)) @@ -258,9 +258,9 @@ } //鍒ゆ柇鏇存柊鍖呴噷鏄惁鏈夎ˉ涓佽剼鏈紝濡傛灉鏈夊垯鎵ц锛屽惁鍒欐墽琛寀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) + updateCmd := fmt.Sprintf("./updatePatch.sh %s %s %s &",unPackPath,zipFilePath,configPatchPath+"/"+identifier) + if util.Exists(unPackPath+"upgrade.sh") { + updateCmd = fmt.Sprintf("%supgrade.sh %s %s %s",unPackPath,unPackPath,zipFilePath,configPatchPath+"/"+identifier) } //2.鏇存柊绯荤粺 b,err := ExecCmd(updateCmd) -- Gitblit v1.8.0