亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mysql數(shù)據(jù)庫增量備份的思路和方法

 更新時間:2017年09月15日 10:50:43   投稿:mrr  
MySQL數(shù)據(jù)庫增量備份,在這之前修改我們的數(shù)據(jù)庫配置文件/etc/my.cnf開啟bin-log日志功能即可,下面小編給大家分享Mysql數(shù)據(jù)庫增量備份的思路詳解,一起看看吧

MySQL數(shù)據(jù)庫增量備份,在這之前修改我們的數(shù)據(jù)庫配置文件/etc/my.cnf開啟bin-log日志功能即可。接下來是我參考了下網(wǎng)上的一些方法,自己寫的,主要還是要能學(xué)到他的一些思路和方法。

#function:MYSQL增量備份
#version:1.0.0
#author:wangyanlin
#date:2017/08/02
#-----------------------------------------------------------------------------------------------
#!/bin/sh
export LANG=en_US.UTF-8
#設(shè)置時間
DATE=`date +%Y%m%d`
#設(shè)置信息
USER=root
PASSWORD=withub
#設(shè)置路徑
cd /
/usr/bin/mkdir -p mysql_bak/daily 
/usr/bin/mkdir -p mysql_bak/logs
BakDir=/mysql_bak/daily
BinDir=/var/lib/mysql
LogFile=/mysql_bak/logs/Daily_$DATE.log
BinlogFile=/var/lib/mysql/mysql-bin.index
/usr/bin/mysqladmin -u$USER -p$PASSWORD flush-logs #刷新日志
Counter=`wc -l $BinlogFile | awk '{print $1}'`
NextNum=0
start_time=`date +'%Y-%m-%d %H:%M:%S'`
echo `date +"%Y年%m月%d日 %H:%M:%S"` $Next1 Bakup start! >> $LogFile
#這個for循環(huán)用于比對$Counter,$NextNum這兩個值來確定文件是不是存在或最新的。
for file in `cat $BinlogFile`
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用于檢測目標(biāo)文件是否存在,存在就寫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"` $Next2 Bakup succ! >> $LogFile
end_time=`date +'%Y-%m-%d %H:%M:%S'`
start_seconds=$(date --date="$start_time" +%s);
end_seconds=$(date --date="$end_time" +%s);
echo "本次備份運(yùn)行時間: "$((end_seconds-start_seconds))"s" >> $LogFile

添加計劃任務(wù):

                       crontab -e

                       00 03 * * * /root/MySQL_incrementbak.sh    #每天的凌晨3點(diǎn)開始增量備份日

logs日志打印出來的效果:

PS:下面看下mysql全量和增量備份腳本

全量:

[root@master leo]# cat DBfullBak.sh 
#!/bin/bash
#use mysqldump to fully backup mysql data
BakDir=/root/leo/full
LogFile=/root/leo/full/bak.log
Date=`date +%Y%m%d`
Begin=`date +"%Y年%m月%d日 %H:%M:%S"`
cd $BakDir
DumpFile=$Date.sql
GZDumpFile=$Date.sql.tgz
mysqldump -uroot -p123456 --all-databases --lock-all-tables --routines --triggers --events --master-data=2 --flush-logs > $DumpFile
tar zcvf $GZDumpFile $DumpFile
rm $DumpFile
Last=`date +"%Y年%m月%d日 %H:%M:%S"`
echo 開始:$Begin 結(jié)束:$Last $GZDumpFile succ >> $LogFile

參數(shù)注釋:

--all-databases #備份所有庫
--lock-all-tables #為所有表加讀鎖
--routinge  #存儲過程與函數(shù)
--triggers  #觸發(fā)器
--events   #記錄事件
--master-data=2 #在備份文件中記錄當(dāng)前二進(jìn)制日志的位置,并且為注釋的,1是不注釋掉在主從復(fù)制中才有意義
--flush-logs  #日志滾動一次

結(jié)果如下:

[root@master full]# ls
20140728.sql.tgz bak.log
[root@master full]# cat bak.log 
開始:2014年07月28日 19:02:59 結(jié)束:2014年07月28日 19:02:59 20140728.sql.tgz succ
開始:2014年07月28日 19:12:01 結(jié)束:2014年07月28日 19:12:01 20140728.sql.tgz succ
[root@master full]#

增量備份:

[root@master leo]# cat DBDailyBak.sh 
#!/bin/bash
BakDir=/root/leo/binlog/
BinDir=/var/lib/mysql
LogFile=/root/leo/binlog/bak.log
BinFile=/var/lib/mysql/mysql-bin.index
mysqladmin -uroot -p123456 flush-logs
Counter=`wc -l $BinFile|awk '{print $1}'`
NextNum=0
for file in `cat $BinFile`
do 
 base=`basename $file`
 NextNum=`expr $NextNum + 1`
 if [ $NextNum -eq $Counter ]
 then
  echo $base skip! >> $LogFile
 else
  dest=$BakDir/$base
  if(test -e $dest)
  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

總結(jié)

以上所述是小編給大家介紹的Mysql數(shù)據(jù)庫增量備份的思路和方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 在EF中使用MySQL的方法及常見問題

    在EF中使用MySQL的方法及常見問題

    這篇文章主要介紹了在EF中使用MySQL的方法及常見問題 的相關(guān)資料,需要的朋友可以參考下
    2016-06-06
  • mysql數(shù)據(jù)如何通過data文件恢復(fù)

    mysql數(shù)據(jù)如何通過data文件恢復(fù)

    這篇文章主要介紹了mysql數(shù)據(jù)如何通過data文件恢復(fù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • MySQL優(yōu)化之使用連接(join)代替子查詢

    MySQL優(yōu)化之使用連接(join)代替子查詢

    有些時候,子查詢可以被更有效的連接替代,方法僅供參考,需要的朋友可以了解下。
    2017-10-10
  • xampp修改mysql默認(rèn)密碼的方法

    xampp修改mysql默認(rèn)密碼的方法

    在這里介紹xampp修改mysql默認(rèn)密碼的大概過程是先利用xampp的phpmyadmin進(jìn)入修改mysql密碼,修改之后我們再修改xampp中phpmyadmin的密碼,這樣就完整的修改mysql默認(rèn)密碼了,感興趣的朋友一起通過本文學(xué)習(xí)吧
    2016-10-10
  • 使用Python的Django框架中的壓縮組件Django Compressor

    使用Python的Django框架中的壓縮組件Django Compressor

    這篇文章主要介紹了使用Python的Django框架中的壓縮組件Django Compressor,這個工具主要用于實現(xiàn)js/css的壓縮,需要的朋友可以參考下
    2015-05-05
  • MySQL無法啟動幾種常見問題小結(jié)

    MySQL無法啟動幾種常見問題小結(jié)

    在群里看到有新同學(xué)還在問MySQL無法啟動的問題,于是總結(jié)了幾個常見情況與解決方法,需要的朋友可以參考下
    2013-09-09
  • Win 8或以上系統(tǒng)下MySQL最新版5.7.17(64bit ZIP綠色版)安裝部署教程

    Win 8或以上系統(tǒng)下MySQL最新版5.7.17(64bit ZIP綠色版)安裝部署教程

    這篇文章主要為大家詳細(xì)介紹了Win 8或以上系統(tǒng)下MySQL最新版5.7.17 64bit ZIP綠色版安裝部署教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Windows系統(tǒng)下MySQL無法啟動的萬能解決方法

    Windows系統(tǒng)下MySQL無法啟動的萬能解決方法

    這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)下MySQL無法啟動的萬能解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 詳解MySQL多表查詢

    詳解MySQL多表查詢

    最近學(xué)習(xí)了多表查詢,這篇文章主要給大家介紹了關(guān)于MySQL多表查詢,文中通過實例代碼介紹的非常詳細(xì),具有一定的參考價值,需要的朋友可以參考下
    2023-04-04
  • MySQL為Null會導(dǎo)致5個問題(個個致命)

    MySQL為Null會導(dǎo)致5個問題(個個致命)

    這篇文章主要介紹了MySQL為Null會導(dǎo)致5個問題(個個致命),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01

最新評論