linux根据文件时间复制文件进行备份

使用的场景

使用linux的定时任务(crontab -e)每天备份一次MySQL的Binlog文件和Redis的aof文件,将文件复制到一块专门用于备份的挂载硬盘(例如nfs)

mkdir /var/backups
cat > /var/backups/mysqldump.sh <<-EOF
export mysqldump_date=$(date +%Y%m%d_%H%M%S) && \
docker exec mysql_container mysqldump -uroot -pmypassword database_name > /var/backups/$mysqldump_date.sql && \
gzip /var/backups/$mysqldump_date.sql && \
find /var/backups/ -name "*.sql" -mtime +15 -exec rm -f {} \;
EOF
# 改权限
chmod 711 /var/backups/mysqldump.sh
# crontab -e
0 20 * * * /var/backups/mysqldump.sh

使用命令详情

find . –mtime中的参数n
find . –mtime n中的n指的是24n, +n、-n、n分别表示:
+n: 大于n
-n: 小于n
n:等于n
find . –mtime n
最后一次修改发生在距离当前时间n
24小时至(n+1)*24 小时
find . –mtime +n
最后一次修改发生在n+1天以前,距离当前时间为(n+1)24小时或者更早
find . –mtime –n
最后一次修改发生在n天以内,距离当前时间为n
24小时以内

# 创建目录,以时间命名
mkdir $(date +%Y-%m-%d)

# 只复制文件
# find /yourdir -mtime -1 -type f -exec cp {} /destdir \;

# 复制文件和目录
find /yourdir -mtime -1 -exec cp -Rp {} /destdir \;

使用stat命令查看修改时间

[root@ls ~]# stat back.sh
  File: ‘back.sh’
  Size: 509       	Blocks: 8          IO Block: 4096   regular file
Device: fd01h/64769d	Inode: 133044      Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2023-05-31 15:14:26.895750168 +0800
Modify: 2022-07-31 18:10:09.633767940 +0800
Change: 2022-07-31 18:10:09.635768039 +0800
 Birth: -

atime是指access time,即文件被读取或者执行的时间,修改文件是不会改变access time的。使用cat、more时atime也不会被修改。
ctime即change time文件状态改变时间,如通过chmod修改文件属性,ctime就会被修改。
mtime即modify time,指文件内容被修改的时间。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值