时间:2021-05-19
问题描述:
最近有个需求,就是rsync每次同步的数据量很多,但是需要保留的数据库bak文件
保留7天就够了,所以需要自动清理文件夹内的bak文件
解决方案:
利用shell脚本来定期删除文件夹内的任务
1、创建shell文件
[root@zabbix script]# vim backup_sql_clean.sh#!/bin/shfind /data1/backup/KDKDA\$AGKDPAYKT/XNAKSD/FXUIJ -mtime +10 -name "*.bak" -exec rm -rf {} \;参数说明:
/data1/backup/KDKDA\$AGKDPAYKT/XNAKSD/FXUIJ #这个是文件的路径path
-mtime +10 #这个是保留的天数,10就是10天
-name "*.bak" #这个是要删除文件的名称,这边加后缀就是删除这个类型的文件
其他的是Linux的命令
2、设置shell文件权限
[root@zabbix script]# chown 777 backup_sql_clean.sh3、设置crontab周期执行
crontab命令用于设置周期性被执行的指令
crontab相关命令说明:
[root@zabbix /]# crontab -e0 0 * * 7 /data/script/backup_sql_clean.sh4、启动crond进程
crond的概念和crontab是不可分割的。crontab是一个命令,常见于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后缀的文件,如:
3、编辑打开该文件,如图:
4、此时按键盘上的“i”键或者“insert”键,进入编辑模式
输入:
#!/bin/shfind /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、设置定时任务
插入“0 4 * * * /data/iqmkj/backup/mysql/backup_mysql_clean.sh”。
说明:
其中的文件路径为第二步中创建的文件路径。
9、保存定时任务配置
按一下键盘上的“esc”键,再在当前窗口输入":wq"。文件即保存成功并自动退回到主界面。
10、启动定时器
在主界面输入“/bin/systemctl start crond.service”。至此全部配置完成。
说明:
启动定时任务:/bin/systemctl start crond.service
停止定时任务:/bin/systemctl stop crond.service
重启定时任务:/bin/systemctl restart crond.service
查看定时任务状态:/bin/systemctl status crond.service
总结
以上所述是小编给大家介绍的解决Centos7下crontab+shell脚本定期自动删除文件问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Linux下使用shell脚本,结合crontab,定时备份MySQL下多个数据库,每次备份的数据存放于以日期命名的文件夹中,同时删除超过设定的备份保留时间的数
CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的。为了解决这个问题,
CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的。为了解决这个问题,
本文实例讲述了Python使用crontab模块设置和清除定时任务操作。分享给大家供大家参考,具体如下:centos7下安装Python的piproot用户使用
目录安装CentOS7配置静态IP通过vi编辑该文件安装centos7这里我们要安装centos764位,所以选择centos764位配置我们点击存储后,vmw