feat(migration): upgrade legacy ps1 scripts to single-binary Golang platform

This commit is contained in:
2026-03-24 14:37:44 +08:00
parent 82eeee50f1
commit f288be2a63
21 changed files with 569 additions and 3015 deletions

70
pkg/logger/logger.go Normal file
View File

@@ -0,0 +1,70 @@
package logger
import (
"io"
"log"
"os"
"path/filepath"
"github.com/fatih/color"
"gopkg.in/natefinch/lumberjack.v2"
"smart-shutdown/pkg/config"
)
var (
infoLogger *log.Logger
succLogger *log.Logger
warnLogger *log.Logger
failLogger *log.Logger
critLogger *log.Logger
)
// InitLogger 初始化全局日志系统,将日志同时输出到终端色彩日志和滚动文件
func InitLogger() error {
logDir := config.GetLogDir()
if err := os.MkdirAll(logDir, 0755); err != nil {
// 降级为当前目录,适用于未具有系统写权限的 Local 执行
logDir = "logs"
os.MkdirAll(logDir, 0755)
}
logFile := filepath.Join(logDir, "network_monitor.log")
// 使用 lumberjack 实现每天轮转和最大保留 30 天功能
ljLogger := &lumberjack.Logger{
Filename: logFile,
MaxSize: 10, // 每个切片最大兆字节 (MB)
MaxBackups: 30, // 保留最近 30 个切片
MaxAge: 30, // 保留最近 30 天的文件
Compress: false, // 是否压缩
}
// 各级别终端色彩
cSucc := color.New(color.FgGreen).SprintFunc()
cFail := color.New(color.FgRed).SprintFunc()
cWarn := color.New(color.FgYellow).SprintFunc()
cCrit := color.New(color.FgHiRed, color.Bold).SprintFunc()
// 构建复合输出写入器:终端标准输出 + 日志文件
outGeneral := io.MultiWriter(os.Stdout, ljLogger)
outError := io.MultiWriter(os.Stderr, ljLogger)
// 时间戳格式前缀
flags := log.Ldate | log.Ltime
// 实例化各个级别 Logger
infoLogger = log.New(outGeneral, "[INFO] ", flags)
succLogger = log.New(outGeneral, cSucc("[SUCCESS] "), flags)
warnLogger = log.New(outGeneral, cWarn("[WARN] "), flags)
failLogger = log.New(outError, cFail("[FAIL] "), flags)
critLogger = log.New(outError, cCrit("[CRITICAL] "), flags)
return nil
}
// 封装导出供业务调用的函数
func Info(format string, v ...interface{}) { infoLogger.Printf(format, v...) }
func Succ(format string, v ...interface{}) { succLogger.Printf(format, v...) }
func Warn(format string, v ...interface{}) { warnLogger.Printf(format, v...) }
func Fail(format string, v ...interface{}) { failLogger.Printf(format, v...) }
func Crit(format string, v ...interface{}) { critLogger.Printf(format, v...) }