视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL数据库定时备份Shell脚本并备份至其它机器方法_MySQL
2020-11-09 18:40:49 责编:小采
文档


bitsCN.com

MySQL数据库定时备份Shell脚本并备份至其它机器方法

这是一个简单的MySQL数据库备份shell脚本,适用于单台Linux服务器或者VPS的mysql数据库备份工作,

工作原理是使用mysql的mysqldump工具来导出数据库为.sql文件,然后将所有导出的文件打包归档。

然后我们在shell脚本中使用 scp命令把备份文件复制到另外一台备份机器,由于scp每次传送文件要密码

因此我们需要使用 expect插件或者利用密钥。在这里介绍采用生成密钥对的方法。

1,生成密匙对,我用的是rsa的密钥。使用命令 "ssh-keygen -t rsa"

生成的过程中提示输入密钥对保存位置及密码,直接回车,接受默认值就行了。

其中公共密钥保存在 ~/.ssh/id_rsa.pub,私有密钥保存在 ~/.ssh/id_rsa 。

2,然后修改 .ssh 目录权限,chmod 755 ~/.ssh 。最后把 公共密钥复制到你要访问

的机器上去,并保存为:~/.ssh/authorized_keys 。

scp -P 1110 ~/.ssh/id_rsa.pub daniel@*.*.*.*:/home/daniel/.ssh/authorized_keys

(注意这里- P 为大写, 表示目标机器daniel 的ssh端口为1110,小写的p为源ssh端口

修改ssh端口在文件/etc/ssh/sshd_config下 。)这里完成scp 脚本免密钥的方法介绍。

最后使用crontab定时执行脚本即可!

脚本如下:

[plain]

#!/bin/bash

# description: MySQL buckup shell script

# author: Daniel

st=$(date +%s)

USER="root"

PASSWORD="*****"#用户名

DATABASE="myblogdb" #数据库用户密码

MAIL="abcd@gmail.com"#mail

BACKUP_DIR=/home/daniel/data_backup/ #备份文件存储路径

LOGFILE=/home/daniel/data_backup/data_backup.log #日志文件路径

DATE=`date +%Y%m%d-%H%M`#用日期格式作为文件名

DUMPFILE=$DATE.sql

ARCHIVE=$DATE.sql.tar.gz

OPTIONS="-u$USER -p$PASSWORD $DATABASE"

#判断备份文件存储目录是否存在,否则创建该目录

if [ ! -d $BACKUP_DIR ]

then

mkdir -p "$BACKUP_DIR"

fi

#开始备份之前,将备份信息头写入日记文件

echo " ">> $LOGFILE

echo "--------------------" >> $LOGFILE

echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE

echo "-------------------" >> $LOGFILE

#切换至备份目录

cd $BACKUP_DIR

mysqldump $OPTIONS > $DUMPFILE

#判断数据库备份是否成功

if [[ $? == 0 ]]

then

tar czvf $ARCHIVE $DUMPFILE >> $LOGFILE 2>&1

echo "[$ARCHIVE] Backup Successful!" >> $LOGFILE

rm -f $DUMPFILE #删除原始备份文件,只需保留备份压缩包

# 把压缩包文件备份到其他机器上。

scp -P $ARCHIVE daniel@*.*.*.*:/home/daniel/data_backup/

else

echo "Database Backup Fail!" >> $LOGFILE

#备份失败后向管理者发送邮件提醒

mail -s "database:$DATABASE Daily Backup Fail!" $MAIL

fi

echo "Backup Process Done"

#删除3天以上的备份文件

#Cleaning

find $BACKUP_DIR -type f -mtime +2 -name "*.tar.gz" -exec rm -f {} /;

修改/etc/crontab

#vi /etc/crontab

在下面添加:

00 03 * * * root /data/backup/dump.sh

注意/data/backup/dump.sh为脚本的存放位置.

表示每天3点钟执行备份。

重新启动crond

# /etc/rc.d/init.d/crond restart

bitsCN.com

下载本文
显示全文
专题