Mysql資料庫增量備份

来源:http://www.cnblogs.com/JeremyWYL/archive/2017/09/15/7525066.html
-Advertisement-
Play Games

MySQL資料庫增量備份,在這之前修改我們的資料庫配置文件/etc/my.cnf開啟bin-log日誌功能即可。接下來是我參考了下網上的一些方法,自己寫的,主要還是要能學到他的一些思路和方法。 添加計劃任務: crontab -e 00 03 * * * /root/MySQL_incrementb ...


MySQL資料庫增量備份,在這之前修改我們的資料庫配置文件/etc/my.cnf開啟bin-log日誌功能即可。接下來是我參考了下網上的一些方法,自己寫的,主要還是要能學到他的一些思路和方法。

#function:MYSQL增量備份
#version:1.0.0
#author:wangyanlin
#date:2017/08/02
#-----------------------------------------------------------------------------------------------
#!/bin/sh
export LANG=en_US.UTF-8
#設置時間
DATE=`date +%Y%m%d`
#設置信息
USER=root
PASSWORD=withub
#設置路徑
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迴圈用於比對$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用於檢測目標文件是否存在,存在就寫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 "本次備份運行時間: "$((end_seconds-start_seconds))"s" >> $LogFile

 

添加計劃任務:

                       crontab -e

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

logs日誌列印出來的效果:

                      

有問題請留言,我們互相交流!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前段時間看到wklken分享的k vim "配置" ,試用了下真的爽到飛起。 不過唯一不爽的是有一些快捷鍵一直記不住,現在整理些常用的快捷鍵,以備查閱。 F2 set nu/nonu F5 set paste/nopaste ctrl+n 相對行號絕對行號變換,預設用相對行號 NERDTree 展開 ...
  • 小編在這兒給大家介紹幾款linux管理面板,希望感興趣的童鞋可以去嘗試下。個人覺得寶塔和appnode這兩個面板不僅從功能和樣式都還是做的比較好的,但是部分功能是收費的,但是webmin絕對是一款免費的軟體。 ...
  • 背景 通常我們在伺服器上使用rsync加上crontab來定時地完成一些同步、備份文件的任務。隨著業務和應用需求的不斷擴大、實時性要求越來越高。一般rsync是通過校驗所有文件後,進行差量同步,如果文件量十分龐大,那麼rsync進行校驗的過程也是十分耗時的。而且正在發生變化的往往是其中很少的一部分, ...
  • 需求:ftp獲取遠程數據的文件,根據文件的創建時間點下載文件。 可以自行擴展根據文件的大小等其他需求。 知識點總結: 1、獲取文件的時間: 時間內容: Sep 8 16:03 2、時間格式轉換 轉換結果: 201709081603 3、指定文件名,正則匹配 註意awk裡面模式變數用' '括起來,.* ...
  • su switch user 用途:用於用戶之間的切換 格式: su USERNAME切換用戶後,同時切換到新用戶的工作環境中 su USERNAME切換用戶後,不改變原用戶的工作目錄,及其他環境變數 退出:exit或logout ctrl+D sudo sudo是一種許可權管理機制,依賴於/etc/ ...
  • 1. 簡介 ​ lua nginx module(ngx_lua module)把 Lua5.1 的解釋器 或 LuaJIT 2.0/2.1 的解釋器嵌入到 nginx 中,將強大的 Lua 線程(Lua threads)與 nginx 事務模型(Nginx event model)相結合,我們可以 ...
  • 一、安裝環境 硬體:虛擬機 操作系統:Centos 7.0 64位 IP:192.168.120.150 hadoop-2.7.0.tar.gz 鏈接:http://pan.baidu.com/s/1eRT0tk2 密碼:ymim jdk-8u45-linux-x64.tar.gz 鏈接:http: ...
  • 經常使用的命令: #查看埠被占用情況 netstat -tunlp|grep 22 #查看java進程 ps -ef|grep java #壓縮前端工程 rar a -ep1 ./update/win32.zip ./packages/**/win32/* #查找所有帶wine的文件和文件夾 fi ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...