文章目录
一、mysql全量备份
使用mysqldump 进行全量备份
1、修改 /etc/my.cnf文件添加如下内容
[mysqldump]
user=your_backup_user_name
password=your_backup_passwor
否则会报:Warning: Using a password on the command line interface can be insecure.
2、测试任务脚本
mysqldump -h localhost -uroot -p123456 --flush-logs --databases databaseName > /home/sql/test.sql
# databaseName 备份的数据库
# /home/sql/test.sql 备份的文件路径及文件
3、添加执行脚本
DB_HOST="localhost" DB_NAME="storage" #你要备份的数据库
BIN_DIR="/usr/bin" BCK_DIR="/usr/local/mysql" #备份文件存放的位置
DATE=`date +%F`
mysqldump -h localhost --flush-logs --databases $DB_NAME > $BCK_DIR/storage_$DATE.sql
4、天假定时任务
定时备份使用linux的 crontab 定时执行任务脚本
0 0 * * * sh /usr/your/path/mysqlBackup.sh
二、mysql增量备份
mysql增量备份需要结合binlog来执行
1、修改 /etc/my.cnf文件添加如下内容
#开启binlog
server_id=2
log_bin=mysql-bin
binlog_format=ROW
[mysqladmin]
user=your_backup_user_name
password=your_backup_password
2、重启mysql
service mysqld restart
3、 添加执行脚本
BakDir=/home/mysql/data #增量备份时复制mysql-bin.00000*的目标目录,提前手动创建这个目录
BinDir=/var/lib/mysql #mysql的数据目录
LogFile=/home/mysql/bak.log
BinFile=/var/lib/mysql/mysql-bin.index #mysql的index文件路径,放在数据目录下
mysqladmin flush-logs
#这个是用于产生新的mysql-bin.00000*文件
Counter=`wc -l $BinFile |awk '{print $1}'`
NextNum=0
#这个for循环用于比对$Counter,$NextNum这两个值来确定文件是不是存在或最新的
for file in `cat $BinFile`
do
base=`basename $file`
#basename用于截取mysql-bin.00000*文件名,去掉./mysql-bin.000005前面的./
NextNum=`expr $NextNum + 1`
if [ $NextNum -eq $Counter ]
then
echo $base skip! >> $LogFile
else
dest=$BakDir/$base
if(test -e $dest)
:#test -e用于检测目标文件是否存在,存在就写exist!到$LogFile去
then
echo $base exist! >> $LogFile
else
cp $BinDir/$base $BakDir
echo $base copying >> $LogFile
fi
fi
done
echo `date +"%Y年%m月%d日 %H:%M:%S"` $Next Bakup succ! >> $LogFile
4、执行恢复
进入到备份的文件路径 即上面配置的 BakDir=/home/mysql/data 执行以下命令
mysqlbinlog mysql-bin.000011 | mysql -u root -p
4、测试是否生效
- 执行全量备份脚本
- 在数据中随便添加一条数据
- 执行增量备份脚本
- 删除刚刚添加的数据
- 查看 binlog备份路径下的文件
- 执行最后一个mysql-bin文件
- 查看数据是否已恢复