mySQL 增量備份方案


1.在 /etc/my.cnf 下面設置開啟bin-log

         編輯

         vim /etc/my.cnf

         [mysqld]

         binlog_format       = MIXED                 //binlog日志格式

         log_bin             =目錄/mysql-bin.log    //binlog日志名

         expire_logs_days    = 7                //binlog過期清理時間

         #max_binlog_size    100m                    //binlog每個日志文件大小 最大值和默認是1個G

         binlog-do-db=game     #需要備份的數據庫名,如果備份多個數據庫,重復設置這個選項即可

         binlog-do-db=platform #

         #binlog-ignore-db=不需要備份的數據庫,如果備份多個數據庫,重復設置這個選項即可

2.創建遠程登陸數據庫帳號

         grant all privileges on game.* to 'jack'@'192.168.10.56' identified by 'admin'

         grant all privileges on platform.* to 'jack'@'192.168.10.56' identified by 'admin'

3.將服務器上的數據,導入一份進遠程服務器中

         mysqldump -ujack -padmin -h192.168.10.38 > 備份數據庫地址(/home/mysql/db/mysql.sql);

4.寫Linux 計划任務:

         vim /etc/crontab

在底部加入

         0 3 * * * root sh /home/wwwroot/sh/mysqlbackup.sh #每天3點以root帳號的權限執行目錄下的sh

重啟服務

         /etc/init.d/crond restart

---------------------------------------------------

如果遇到了問題,請查看一下

select super_priv,user from user where host='192.168.10.39';

update user set super_priv='Y' where user='game1';

 

#! /bin/Bash
##################
# 2013-9-24      #
# author jackluo #
##################
db_user= #遠程mysql用戶名    
db_pwd= #遠程mysql密碼
db_host= #遠程ip
mysql_bin=/usr/local/mysql/bin/ #mysql 執行【招待】目錄
mysqlbindir=/usr/local/mysql/var/ #binlog日志存放目錄
dailyBackupDir=/root/mysql/ #存放,導入成功的日志
binlogname="mysql-bin" #binlog日志前綴
cd $mysqlbindir 
fileList=`cat mysql-bin.index` 
iCounter=0
for file in $fileList
do 
    iCounter=`expr $iCounter + 1 `
    echo ${file}
done
nextNum=0
for file in $fileList
do
   binLogName=`basename $file ` 
   nextNum=`expr $nextNum + 1 `
   if [[ $nextNum == $iCounter ]]; then
    echo "Skip lastest!" > /dev/null
    else
    dest=$dailyBackupDir/$binLogName
    if [[ -e $dest ]]; then #檢查是否已導入過了
        echo "Skip exist $binLogName!" > /dev/null
    else
        ${mysql_bin}mysqlbinlog $binLogName|mysql -h${db_host} -u${db_user} -p${db_pwd} #寫入遠程數據庫
        if [[ ! -d ${dailyBackupDir} ]];then
                        mkdir -p ${dailyBackupDir}
        fi
        touch ${dest} #創建日志文件
        find . -type f -ctime +6 -exec rm {} \; #刪除6天后的日志文件
    fi    
   fi
done

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM