Go本地定时备份工具需实现三大核心:安全递归复制文件、生成时间戳备份路径、按计划执行;可通过系统定时器(cron/任务计划)或time.Ticker内置轮询触发;支持JSON配置、排除规则、自动清理旧备份。
用 Go 写一个本地定时备份工具并不难,核心是三件事:复制文件/目录、生成带时间戳的备份路径、按计划触发执行。Go 本身没有内置“定时任务”模块,但可以轻松集成系统级定时器(如 cron 或 Windows Task Scheduler),或在程序内用 time.Ticker 实现简易轮询——后者适合轻量、单机、不跨重启的场景。
备份的本质是可靠拷贝。不要用 os.Rename(可能跨设备失败),优先用递归复制逻辑。可借助标准库 filepath.WalkDir 遍历源路径,对每个文件调用 io.Copy 写入目标位置。
backup_20250520_143022,可用 time.Now().Format("20060102_150405") 生成os.MkdirAll 创建os.FileInfo.Mode() & os.ModeSymlink != 0
log.Printf 记录成功/跳过/错误项,便于排查硬编码路径不利于维护。推荐新建 config.json 文件,结构类似:
{
"sources": ["/home/user/docs", "/etc/nginx"],
"destination": "/backups",
"exclude_patterns": ["*.tmp", ".git", "node_modules"],
"keep_last": 5
}用 encoding/json 解析后,即可动态读取。排除规则可用 path/filepath.Match 判断是否跳过某路径;keep_last 字段用于后续清理旧备份。
备份不清理会撑爆磁盘。可在每次新备份完成后,扫描目标目录下所有以 backup_ 开头的子目录,按名称中时间戳排序,保留最新的 N 个,其余 os.RemoveAll。
20250520_143022 是升序字符串),否则排序失效-dry-run 标志做预演,避免误删filepath.WalkDir 完全结束
),再开始删旧方式 A(推荐):交给系统定时器
Linux/macOS 下,把编译好的二进制(如 ./backup-tool)写进 crontab:
0 2 * * * /home/user/bin/backup-tool -config /home/user/config.json
每天凌晨 2 点运行。Windows 可用任务计划程序,触发器设为“每天”,操作为“启动程序”,参数填配置路径。
方式 B:内置简单定时器(适合开发测试)
主函数中用 time.NewTicker 每 24 小时触发一次备份(注意:进程需常驻):
ticker := time.NewTicker(24 * time.Hour)
for range ticker.C {
runBackup(config)
}这种方式简单,但机器重启后不会自动恢复,也不如 cron 精确可靠,生产环境慎用。