linux定时备份MySQL数据库并删除七天前的备份文件

2 篇文章 0 订阅
1 篇文章 0 订阅

mysql 备份

备份还原某个数据库

备份还原



# 导出数据库
/usr/bin/mysqldump -u root -ppwd database > database20160929.sql
# 导入数据库
mysql -u root -p database < database20160929.sql
#备份到压缩文件
/usr/bin/mysqldump -u root -ppwd database | gzip > database20160929.sql.gz
#从压缩文件导入
gzip < database20160929.sql.gz | mysql -u root -p database
crontab定时备份
1、创建备份目录
# root 用户,创建备份目录
mkdir -p /bak/mysqlbak
cd /bak/mysqldata
2、编写运行脚本

vi /usr/sbin/bakmysql.sh
脚本代码:
#!/bin/bash
# Name:bakmysql.sh
# This is a ShellScript For Auto DB Backup and Delete old Backup
#
backupdir=/bak/mysqlbak
time=` date +%Y%m%d%H `
mysql_bin_dir/mysqldump -u root -ppwd database | gzip > $backupdir/database$time.sql.gz
#
find $backupdir -name "name_*.sql.gz" -type f -mtime +7 -exec rm {} ; > /dev/null 2>&1

#
脚本说明:
backupdir mysql备份地址
root mysql用户名
pwd mysql密码
database 数据库名
mysql_bin_dir mysql的bin路径;
time=` date +%Y%m%d%H `也可以写为time="$(date +"%Y%m%d$H")"其中`符号是TAB键上面的符号,不是ENTER左边的'符号,还有date后要有一个空格。
type f 表示查找普通类型的文件,f表示普通文件。
mtime +7 按照文件的更改时间来查找文件,+5表示文件更改时间距现在7天以前;如果是 -mmin +5 表示文件更改时间距现在5分钟以前。
exec rm {} \ 表示执行一段shell命令,exec选项后面跟随着所要执行的命令或脚本,然后是一对儿{},一个空格和一个\,最后是一个分号。
/dev/null 2>&1 把标准出错重定向到标准输出,然后扔到/DEV/NULL下面去。通俗的说,就是把所有标准输出和标准出错都扔到垃圾桶里面;其中的& 表示让该命令在后台执行。

3、为脚本添加执行权限

# chmod +x /usr/sbin/bakmysql.sh
4、设置crontab定时执行

vi /etc/crontab
#在最后一行中加入:
00 3 * * * root /usr/sbin/bakmysql.sh
#表示每天3点00分执行备份
注:crontab配置文件格式如下:
分 时 日 月 周  命令

5、重启crontab
先用查询状态命令查询crond状态,如果处在停止状态则须先启动;如已在启动状态,则无须理会。

操作命令如下:

/sbin/service crond start 启动

/sbin/service crond restart 重启

/sbin/service crond stop 停止

/sbin/service crond status 查询状态


这样就完了定时备份并清理前7天的备份数据


您可以使用`cron`定时任务来实现定时备份MySQL数据库,并设置备份数据只保留7天。 首先,您需要创建一个Shell脚本来执行MySQL备份操作。打开一个文本编辑器,输入以下内容: ```bash #!/bin/bash # 定义备份目录和文件名 backup_dir="/path/to/backup/directory" backup_file="mysql_backup_$(date +%Y%m%d%H%M%S).sql" # 执行备份命令 mysqldump -u <username> -p<password> <database_name> > "$backup_dir/$backup_file" # 删除旧的备份文件 find "$backup_dir" -name "mysql_backup_*" -type f -mtime +7 -exec rm {} \; ``` 请确保将`/path/to/backup/directory`替换为实际的备份目录,并将`<username>`、`<password>`和`<database_name>`替换为实际的MySQL用户名、密码和数据库名。 保存脚本文件,并赋予执行权限: ```bash chmod +x mysql_backup.sh ``` 接下来,您需要设置一个cron定时任务来定期执行该脚本。运行以下命令编辑cron表: ```bash crontab -e ``` 在打开的文件中添加以下行,每天执行一次备份任务(此处假设您希望在每天的凌晨1执行): ``` 0 1 * * * /path/to/mysql_backup.sh ``` 保存并关闭文件。现在,每天凌晨1cron将自动执行您的备份脚本,并将生成的备份文件保存在指定的目录中。旧的备份文件将在每次备份时被删除,以确保只保留最近7天的备份数据。 请注意,为了安全起见,确保仅允许具有足够权限的用户访问备份目录和脚本文件,并妥善保管MySQL数据库的用户名和密码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值