Linux——MySQL数据库自动备份

Linux如何将Mysql数据库自动从一台服务器备份到另一台服务器

一、概述: 备份是容灾的基础,是指为防止系统出现操作失误或系统故障导致数据丢失,而将全部或部分数据集合从应用主机的硬盘或阵列复制到其它的存储介质的过程。而对于一些网站、系统来说,数据库就是一切,所以做好数据库的备份是至关重要的!
那么Linux如何实现将Mysql数据库自动从服务器A备份到服务器B呢?

二、通过Linux的scp命令:用于Linux之间复制文件和目录。

  1. scp在建立连接中是需要密码认证的,所以我们第一步就是在服务器A上添加ssh公匙
    ssh-keygen -t rsa
  2. 结果:会在用户目录~/.ssh/产生两个文件,id_rsa,id_rsa.pub
  3. 将id_rsa.pub文件拷贝到服务器B的/root/.ssh目录下,并命名authorized_keys,即
    scp /root/.ssh/id_rsa.pub [email protected]:/root/.ssh/authorized_keys
    这样从服务器A复制到服务器B就不需要密码了。

三、编写备份数据库脚本,使得每天固定时间,自动对数据库进行备份 bakmysql.sh

#!/bin/bash
#备份路径
BACKUP=/www/backup/mysql
#当前时间
DATETIME=$(date +%Y-%m-%d)
echo "===备份开始==="
echo "备份文件存放于${BACKUP}/$DATABASE-$DATETIME.sql"
#数据库地址
HOST=localhost
#数据库用户名
DB_USER=root
#数据库密码
DB_PW=123456
#创建备份目录
#[ ! -d "${BACKUP}/$DATETIME" ] && mkdir -p "${BACKUP}/$DATETIME"

#后台系统数据库
DATABASE=db_test
echo $DATABASE-$DATETIME
#mysqldump -u${DB_USER} -p${DB_PW} --single-transaction --host=$HOST -q -R --databases $DATABASE | gzip > ${BACKUP}/$DATETIME/$DATABASE.sql
mysqldump -h localhost  -u${DB_USER} -p${DB_PW}  ${DATABASE} >${BACKUP}/$DATABASE-$DATETIME.sql

echo "===导出成功,开始传输==="
#压缩成tar.gz包
cd $BACKUP
#tar -zcvf $DATETIME.tar.gz $DATETIME
#备份到服务器B
scp $DATABASE-$DATETIME.sql [email protected]:/www/backup/mysql
#删除备份目录
rm -rf ${BACKUP}/$DATETIME

#删除10天前备份的数据,这边可以自行更改
#find $BACKUP -mtime +10 -name "*.sql" -exec rm -rf {} \;
echo "===数据库备份到服务器成功==="

将sh脚本文件放到服务器A任一位置,我这边放在了/www/backup下

四、脚本编写完,利用Linux系统的crontab定时任务,去实现固定时间自动执行脚本

  1. 输入crontab -e,开始编辑定时任务
  2. 输入以下代码59 23 * * * /www/backup/bakmysql.sh #通过vi命令编辑insert,表示每天23:59自动执行代码
  3. 输入:wq! 保存退出
  4. 输入service crond restart 重启服务,如果是ubuntu系统,则是cron

五、Linux—crontab相关命令:

  • crontab –e : 修改 crontab 文件. 如果文件不存在会自动创建

  • crontab –l : 显示 crontab 文件

  • crontab -r : 删除 crontab 文件

  • crontab -ir :删除 crontab 文件前提醒用户

  • 例如:

    # 在 12:01 a.m 运行,即每天凌晨过一分钟。
    # 这是一个恰当的进行备份的时间,因为此时系统负载不大。
    1 0 * * * /root/bin/backup.sh
    
    #每个工作日(Mon – Fri) 11:59 p.m 都进行备份作业。
    59 11 * * 1,2,3,4,5 /root/bin/backup.sh
    
    # 每5分钟运行一次命令
    */5 * * * * /root/bin/check-status.sh 
    
    #每个月的第一天 1:10 p.m 运行
    10 13 1 * * /root/bin/full-backup.sh 
    
    #每个工作日 11 p.m 运行。
    0 23 * * 1-5 /root/bin/incremental-backup.sh
    

PS:务必要养成备份的好习惯啊,不然自己留下的坑,哭着也要填完。

你可能感兴趣的:(Liunx,linux,mysql)