时间:2021-05-22
公司用到的MySQL数据库,经常有同事通过一顿骚操作把一些关键的配置数据误删,每次恢复都要花上不少时间,于是写了个shell脚本,结合corntab每天凌晨备份数据库,并保留7天。
同样的备份脚本也可用于生产环境MySQL数据库定时备份。
环境:CentOS 7.5 / MySQL 5.7
保存成 backupDB.sh 脚本后,执行脚本验证一下。查看BAK_DIR备份目录下的db_backup.log可以看到备份的执行情况。
-------------------2020-09-02_21:33:01 start ---------------
--- backup file created: /home/db_backup/db_backup_20200902.tar.gz
-------------------2020-09-02_21:33:18 end ---------------
验证没问题后,通过crontab -e配置成定时任务执行,要注意的是,mysqldump备份执行时是会锁表的,建议在凌晨没什么人操作数据库的时候执行备份操作。
# 每天凌晨3点执行0 3 * * * sh /home/backupDB.sh > /dev/null 2>&1 &注意:
如果不希望备份时锁表,可以在mysqldump命令中添加参数--skip-lock-tables;
上述脚本中指定了要备份的数据库,如果想备份所有数据库,则无需指定数据库,在mysqldump命令中添加参数--all-databases即可。
到此这篇关于shell脚本定时备份MySQL数据库数据并保留指定时间的文章就介绍到这了,更多相关shell定时备份MySQL内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Linux下使用shell脚本,结合crontab,定时备份MySQL下多个数据库,每次备份的数据存放于以日期命名的文件夹中,同时删除超过设定的备份保留时间的数
每天定时备份mysql数据库任务,删除指定天数前的数据,保留指定天的数据;需求:1,每天4点备份mysql数据;2,为节省空间,删除超过3个月的所有备份数据;3
每天定时备份数据库需要用到Linux的定时任务,利用Linux的crondtab命令。下面我们来看详细步骤:一、写好shell脚本mysqlbak.sh#!/b
备份数据库的shell脚本一复制代码代码如下:#!/bin/bash#指定运行的脚本shell#运行脚本要给用户执行权限bakdir=/backupmonth=
如下脚本用于mysql全库定时备份mysql_dump_script.sh#!/bin/bash#保存备份个数,最多保留4个文件number=4#备份保存路径b