mirror of https://github.com/jetkvm/kvm.git
refactor: rename error dump file
This commit is contained in:
parent
ff81768b88
commit
a3f7b5e937
56
cmd/main.go
56
cmd/main.go
|
|
@ -18,7 +18,7 @@ import (
|
||||||
const (
|
const (
|
||||||
envChildID = "JETKVM_CHILD_ID"
|
envChildID = "JETKVM_CHILD_ID"
|
||||||
errorDumpDir = "/userdata/jetkvm/"
|
errorDumpDir = "/userdata/jetkvm/"
|
||||||
errorDumpStateFile = ".has_error_dump"
|
errorDumpLastFile = "last-crash.log"
|
||||||
errorDumpTemplate = "jetkvm-%s.log"
|
errorDumpTemplate = "jetkvm-%s.log"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -140,30 +140,24 @@ func ensureSymlink(dst, src string) error {
|
||||||
return os.Symlink(src, dst)
|
return os.Symlink(src, dst)
|
||||||
}
|
}
|
||||||
|
|
||||||
func createErrorDump(logFile *os.File) {
|
func renameFile(f *os.File, newName string) error {
|
||||||
logFile.Close()
|
f.Close()
|
||||||
|
|
||||||
// touch the error dump state file
|
// try to rename the file first
|
||||||
if err := os.WriteFile(filepath.Join(errorDumpDir, errorDumpStateFile), []byte{}, 0644); err != nil {
|
if err := os.Rename(f.Name(), newName); err == nil {
|
||||||
return
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
fileName := fmt.Sprintf(errorDumpTemplate, time.Now().Format("20060102150405"))
|
// copy the log file to the error dump directory
|
||||||
filePath := filepath.Join(errorDumpDir, fileName)
|
fnSrc, err := os.Open(f.Name())
|
||||||
if err := os.Rename(logFile.Name(), filePath); err == nil {
|
|
||||||
fmt.Printf("error dump created: %s\n", filePath)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
fnSrc, err := os.Open(logFile.Name())
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return fmt.Errorf("failed to open file: %w", err)
|
||||||
}
|
}
|
||||||
defer fnSrc.Close()
|
defer fnSrc.Close()
|
||||||
|
|
||||||
fnDst, err := os.Create(filePath)
|
fnDst, err := os.Create(newName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return fmt.Errorf("failed to create file: %w", err)
|
||||||
}
|
}
|
||||||
defer fnDst.Close()
|
defer fnDst.Close()
|
||||||
|
|
||||||
|
|
@ -171,20 +165,38 @@ func createErrorDump(logFile *os.File) {
|
||||||
for {
|
for {
|
||||||
n, err := fnSrc.Read(buf)
|
n, err := fnSrc.Read(buf)
|
||||||
if err != nil && err != io.EOF {
|
if err != nil && err != io.EOF {
|
||||||
return
|
return fmt.Errorf("failed to read file: %w", err)
|
||||||
}
|
}
|
||||||
if n == 0 {
|
if n == 0 {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, err := fnDst.Write(buf[:n]); err != nil {
|
if _, err := fnDst.Write(buf[:n]); err != nil {
|
||||||
|
return fmt.Errorf("failed to write file: %w", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func createErrorDump(logFile *os.File) {
|
||||||
|
fileName := fmt.Sprintf(
|
||||||
|
errorDumpTemplate,
|
||||||
|
time.Now().Format("20060102-150405"),
|
||||||
|
)
|
||||||
|
|
||||||
|
filePath := filepath.Join(errorDumpDir, fileName)
|
||||||
|
if err := renameFile(logFile, filePath); err != nil {
|
||||||
|
fmt.Printf("failed to rename file: %v\n", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fmt.Printf("error dump copied: %s\n", fileName)
|
||||||
|
|
||||||
|
if err := ensureSymlink(filePath, filepath.Join(errorDumpDir, errorDumpLastFile)); err != nil {
|
||||||
|
fmt.Printf("failed to create symlink: %v\n", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Printf("error dump created: %s\n", filePath)
|
|
||||||
|
|
||||||
_ = ensureSymlink(filePath, filepath.Join(errorDumpDir, "last-crash.log"))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func doSupervise() {
|
func doSupervise() {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue