问题描述:
近来有个需求,就是rsync每次同步的数据量好多,而且须要保留的数据库bak文件
保留7天就够了,所以须要手动清除文件夹内的bak文件
解决方案:
借助shell脚本来定期删掉文件夹内的任务
1、创建shell文件
[root@zabbix script]# vim backup_sql_clean.sh #!/bin/sh find /data1/backup/KDKDA$AGKDPAYKT/XNAKSD/FXUIJ -mtime +10 -name "*.bak" -exec rm -rf {} ;
参数说明:
/data1/backup/KDKDA$AGKDPAYKT/XNAKSD/FXUIJ#这个是文件的路径path
-mtime+10#这个是保留的天数linux服务器配置与管理,10就是10天
-name"*.bak"#这个是要删掉文件的名称,那边加后缀就是删掉这个类型的文件
2、设置shell文件权限
[root@zabbix script]# chown 777 backup_sql_clean.sh
3、设置crontab周期执行
crontab命令用于设置周期性被执行的指令
crontab相关命令说明:
[root@zabbix /]# crontab -e 0 0 * * 7 /data/script/backup_sql_clean.sh
4、启动crond进程
crond的概念和crontab是不可分割的。crontab是一个命令unix命令 清空文件内容,常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令。
该命令从标准输入设备读取指令,并将其储存于“crontab”文件中,以供然后读取和执行。而crond正是它的守护进程。
[root@zabbix /]# systemctl status crond.service #查看crond状态 [root@zabbix /]# systemctl start crond.service #启动crond服务 [root@zabbix /]# systemctl restart crond.service #重启crond服务
补充;
下边介绍下centOS7定时删掉文件
1、进入linux系统
2、在任意目录创建一个sh后缀的文件linux虚拟主机,如:
3、编辑打开该文件,如图:
4、此时按按键上的“i”键或则“insert”键,步入编辑模式
输入:
#!/bin/sh find /data/iqmkj/backup/mysql -mtime +7 -name "*.sql" -exec rm -rf {} ;
如图:
说明:
“/data/iqmkj/backup/mysql”:要删掉的文件所在的目录。
“+7”:文件保留天数,即几天前的文件将被删掉。
“*.sql”:删掉文件后缀为.sql的文件。
其他为固定字符。
5:保存编辑的文件
按一下按键上的“esc”键,再在当前窗口输入":wq"。文件即保存成功并手动退回到主界面。
6、给文件授权
输入:
chown 777 backup_mysql.sh
假如授权不成功,则直接选中该文件右键设置权限中全部勾选或则设置“777”。
7:借助centos7的定时任务创建一个定时器
在主界面输入”crontab-e”,步入定时任务编辑界面。
8、设置定时任务
插入“04***/data/iqmkj/backup/mysql/backup_mysql_clean.sh”。
说明:
其中的文件路径为第二步中创建的文件路径。
9、保存定时任务配置
按一下按键上的“esc”键unix命令 清空文件内容,再在当前窗口输入":wq"。文件即保存成功并手动退回到主界面。
10、启动定时器
在主界面输入“/bin/systemctlstartcrond.service”。至此全部配置完成。
说明:
启动定时任务:/bin/systemctlstartcrond.service
停止定时任务:/bin/systemctlstopcrond.service
重启定时任务:/bin/systemctlrestartcrond.service
查看定时任务状态:/bin/systemctlstatuscrond.service