Linux下Mysql备份脚本

 1.自动备份脚本

[root@icoolkj mysqlbak]# vi mysqlbak.sh 
# !/bin/bash
# 名称:mysqlbak.sh
# 本地存放备份数据库目录
backupdir=/data/backups/mysqlbak
# 如果文件夹不存在,创建文件夹
if [ ! -d $backupdir ]; then
  mkdir -p $backupdir
  echo -e "备份目录 $backupdir 创建成功。"
else
  echo "备份目录 $backupdir 已经存在。"
fi

# 备份文件后缀时间
time="$(date +%Y%m%d_%H%M%S)" 

echo "开始备份数据库..."

# 注意数据库备份密码 设置在/etc/my.cnf中
# 备份所有数据库到本地(不压缩)
# echo '/data/mysql8/bin/mysqldump --opt --all-databases > $backupdir/all_$time.sql'
# 压缩
/data/mysql8/bin/mysqldump --opt --all-databases | gzip >  $backupdir/all_$time.sql.gz

echo "备份数据完成。"

# 备份单个数据库(不压缩)
# /data/mysql8/bin/mysqldump --databases test > $backupdir/test_$time.sql

# 只保留7天的备份文件
find $backupdir -name "all_*.sql.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
echo "删除备份成功。"


## 然后修改脚本权限
[root@icoolkj mysqlbak]# chmod +x mysqlbak.sh

## 手动执行测试脚本正确性
[root@icoolkj mysqlbak]# sh mysqlbak.sh

温馨提示:脚本弄好后执行看是否有问题,没问题后再设置每天自动备份。

2.设置每天自动执行脚本

1)修改定时任务

crontab -e

2)修改定时任务内容

00 06  * * * /data/backups/mysqlbak/mysqlbak.sh

3)查看定时任务

[root@gaj-zhyq-yyserver2 mysqlbak]# crontab -l
00 06 * * * /data/backups/mysqlbak/mysqlbak.sh

------------------------------------------------------------------
用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:

minute   hour   day   month   week   command

其中:

minute: 表示分钟,可以是从0到59之间的任何整数。

hour:表示小时,可以是从0到23之间的任何整数。

day:表示日期,可以是从1到31之间的任何整数。

month:表示月份,可以是从1到12之间的任何整数。

week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。

command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。

在以上各个字段中,还可以使用以下特殊字符:

星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。

逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”

中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”

正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值