首頁 資料庫 mysql教程 MySQL数据库定时备份Shell脚本并备份至其它机器方法_MySQL

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

Jun 01, 2016 pm 01:31 PM
工作原理 資料庫備份 伺服器

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
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SOL幣是什麼? SOL幣的工作原理是什麼? SOL幣是什麼? SOL幣的工作原理是什麼? Mar 16, 2024 am 10:37 AM

SOL幣是什麼? SOL幣的工作原理是什麼?

如何將Dnsmasq設定為DHCP中繼伺服器 如何將Dnsmasq設定為DHCP中繼伺服器 Mar 21, 2024 am 08:50 AM

如何將Dnsmasq設定為DHCP中繼伺服器

Spring Data JPA 的架構和工作原理是什麼? Spring Data JPA 的架構和工作原理是什麼? Apr 17, 2024 pm 02:48 PM

Spring Data JPA 的架構和工作原理是什麼?

Polygon幣是什麼? Polygon幣的工作原理是什麼? Polygon幣是什麼? Polygon幣的工作原理是什麼? Mar 16, 2024 am 09:22 AM

Polygon幣是什麼? Polygon幣的工作原理是什麼?

VET幣是什麼? VET幣的工作原理是什麼? VET幣是什麼? VET幣的工作原理是什麼? Mar 16, 2024 am 11:40 AM

VET幣是什麼? VET幣的工作原理是什麼?

如何在伺服器上安裝 PHP FFmpeg 擴充功能? 如何在伺服器上安裝 PHP FFmpeg 擴充功能? Mar 28, 2024 pm 02:39 PM

如何在伺服器上安裝 PHP FFmpeg 擴充功能?

SHIB幣是什麼? SHIB幣的工作原理是什麼? SHIB幣是什麼? SHIB幣的工作原理是什麼? Mar 17, 2024 am 08:49 AM

SHIB幣是什麼? SHIB幣的工作原理是什麼?

Algorand幣是什麼? Algorand幣的工作原理是什麼? Algorand幣是什麼? Algorand幣的工作原理是什麼? Mar 17, 2024 am 08:30 AM

Algorand幣是什麼? Algorand幣的工作原理是什麼?

See all articles