使用的场景
使用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
最后一次修改发生在距离当前时间n24小时至(n+1)*24 小时
find . –mtime +n
最后一次修改发生在n+1天以前,距离当前时间为(n+1)24小时或者更早
find . –mtime –n
最后一次修改发生在n天以内,距离当前时间为n24小时以内
# 创建目录,以时间命名
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,指文件内容被修改的时间。