mysql增量備份腳本

来源:https://www.cnblogs.com/xgsh/archive/2023/02/25/17153883.html
-Advertisement-
Play Games

2、增量備份 2.1、添加備份腳本 [root@localhost]# vim /mnt/data/backup/mysql/mysql_m_bak_diff.sh #!/bin/bash #mysql 增量備份 time=`date +%Y%m%d` now=`date +%F' '%T` eti ...


2、增量備份

2.1、添加備份腳本

[root@localhost]# vim /mnt/data/backup/mysql/mysql_m_bak_diff.sh
#!/bin/bash
#mysql 增量備份
time=`date +%Y%m%d`
now=`date +%F' '%T`
etime=`date -d '-7 day' +%Y%m%d`
#備份文件路徑
mkdir -p /mnt/data/backup/mysql/diff_back/$time
mkdir -p /mnt/data/backup/mysql/diff_back/$time/log
backupdir="/mnt/data/backup/mysql/diff_back/$time"
log_dir="/mnt/data/backup/mysql/diff_back/$time/log"
#bin-log日誌文件路徑
BinFile="/mnt/data/mysql/logs/"
user=root
passwd=123456echo "$now 重新生成binlog日誌" >> $log_dir/$time.log
/mnt/data/mysql/bin/mysqladmin -P3308 -u$user -p$passwd --socket=/mnt/data/mysql/mysql.sock flush-logs
if [ $? -eq 0 ];then
    echo "$now binlog日誌重新生成成功" >> $log_dir/$time.log
    echo "$now Begin backup mysql database" >> $log_dir/$time.log
    #查找binlog日誌
    new_blog=`/mnt/data/mysql/bin/mysql -P3308 -u$user -p$passwd --socket=/mnt/data/mysql/mysql.sock -e "show master status\G" |grep 'File'|awk '{print $2}'`
    num=`/mnt/data/mysql/bin/mysql -P3308 -u$user -p$passwd --socket=/mnt/data/mysql/mysql.sock -e "show master status\G" |grep 'File'|awk '{print $2}'|awk -F '.' '{print $2}'`
    next_num=`expr $num - 1`
    old_blog=`find $BinFile -name "mysql-bin.*$next_num"`
    #備份文件
    \cp  $old_blog $backupdir/
    old_blog_n=`find $backupdir -name "mysql-bin.*$next_num"`
    mv $old_blog_n $backupdir/master_bak_$time.sql
        if [ $? -eq 0 ];then
            echo "$now mysql copy successfully " >> $log_dir/$time.log
            echo "$now 開始執行壓縮......" >> $log_dir/$time.log
            tar -zcvf $backupdir/master_bak_$time.tar.gz -C  $backupdir master_bak_$time.sql
            if [ $? -eq 0 ];then
                echo  "$now 文件壓縮成功......" >> $log_dir/$time.log
                rm -rf $backupdir/master_bak_$time.sql
                size=`du -sh $backupdir/master_bak_$time.tar.gz |awk '{print $1}'`
                echo "$now backup mysql database successfully completed" >> $log_dir/$time.log
                echo "$now deploy-主資料庫數據備份成功——增量備份,文件大小為:$size\n 二進位文件為: $old_blog_n" > /tmp/tmp.log
                rm -rf /tmp/tmp.log
            else
                echo  "$now 文件壓縮失敗......" >> $log_dir/$time.log
                echo "$now deploy-主資料庫數據備份成功__增量備份,但文件壓縮失敗,\n 二進位文件為: $old_blog_n " > /tmp/tmp.log
                rm -rf /tmp/tmp.log
            fi
        else
            echo "$now backup mysql database faild" >> $log_dir/$time.log
            echo "$now deploy-主資料庫數據備份失敗——增量備份,請檢查mysql是否正常" > /tmp/tmp.log
            rm -rf /tmp/tmp.log
        fielse
    echo "$now binlog日誌重新生成失敗" >> $log_dir/$time.log
    echo "$now deploy-主資料庫數據備份失敗__差量備份,刷新binlog日誌失敗" > /tmp/tmp.log
    rm -rf /tmp/tmp.log
fi

2.2、添加執行許可權

[root@localhost ~]# chmod +x /mnt/data/backup/mysql/mysql_m_bak_diff.sh

2.3、添加計劃任務

[root@localhost ~]# crontab -e   #添加內容,每天2點執行
0 2 * * * sh /mnt/data/backup/mysql/mysql_m_bak_diff.sh

#wq保存退出

2.4、手動備份

[root@localhost ~]# sh /mnt/data/backup/mysql/mysql_m_bak_diff.sh
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
mysql: [Warning] Using a password on the command line interface can be insecure.
mysql: [Warning] Using a password on the command line interface can be insecure.
master_bak_20230223.sql

2.5、查看備份文件

[root@localhost ~]# ll -h /mnt/data/backup/mysql/diff_back/20230223/
總用量 120K
drwxr-xr-x. 2 root root   26 2月 23 14:22 log
-rw-r--r--. 1 root root 119K 2月 23 14:40 master_bak_20230223.tar.gz
[root@ops deploy]# cat /mnt/data/backup/mysql/diff_back/20230223/log/20230223.log
2023-02-23 14:40:07 重新生成binlog日誌
2023-02-23 14:40:07 binlog日誌重新生成成功
2023-02-23 14:40:07 Begin backup mysql database
2023-02-23 14:40:07 mysql copy successfully
2023-02-23 14:40:07 開始執行壓縮......
2023-02-23 14:40:07 文件壓縮成功......
2023-02-23 14:40:07 backup mysql database successfully completed

2.6、增量數據恢復

[root@localhost ~]# mysqlbinlog --no-defaults --start-datetime="2022-10-31 17:53:00" --stop-datetime="2022-11-01 16:18:00" --database=dbname   mysql-bin.000073 | mysql -uroot -p123456     #指定時間段,指定庫進行恢復

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

-Advertisement-
Play Games
更多相關文章
  • PHP使用ZipArchive批量打包壓縮文件,並下載。使用php自帶的ZipArchive類,可以壓縮或解壓文件。 首先需要確定已經安裝了zip擴展,如果沒有安裝,請先安裝,下載:http://pecl.php.net/package/zip (相應php版本的zip包) 先把需要下載的文件路徑找 ...
  • .NET Core 依賴註入的基本用法 話接上篇,這一章介紹 .NET Core 框架自帶的輕量級 Ioc 容器下服務使用的一些知識點,大家可以先看看上一篇文章 [ASP.NET Core - 依賴註入(一)] 2.3 服務解析 通過 IServiceCollection 註冊了服務之後,可以通過以 ...
  • RestSharp RestSharp是一個輕量的,不依賴任何第三方的模擬Http的組件或者類庫。RestSharp具體以下特性;支持net4.0++,支持HTTP的GET, POST, PUT, HEAD, OPTIONS, DELETE等操作,支持oAuth 1, oAuth 2, Basic, ...
  • CAN 是一種典型的廣播式網路, 在實際應用中, 如果只希望接收到特定類型的數據, 就要藉助過濾器來實現. AIR32/STM32的CAN控制器包含14個過濾器, 可以設置為 屏蔽模式 或 列表模式 對CAN匯流排上的報文進行過濾. 當節點希望接收到一種報文時, 可以用屏蔽位模式進行過濾, ...
  • 痞子衡嵌入式半月刊: 第 72 期 這裡分享嵌入式領域有用有趣的項目/工具以及一些熱點新聞,農曆年分二十四節氣,希望在每個交節之日準時發佈一期。 本期刊是開源項目(GitHub: JayHeng/pzh-mcu-bi-weekly),歡迎提交 issue,投稿或推薦你知道的嵌入式那些事兒。 上期回顧 ...
  • 環境 系統:Ubuntu 20.04 虛擬平臺:Vmware Workstation 16 PRO 軟體版本:Zabbix 6.0 LTS 資料庫:PostgreSQL Web服務:Apache 新建虛擬機(物理機跳過) Ubuntu安裝優化 安裝Zabbix倉庫 wget https://repo ...
  • 前天寫SQL時本想通過 A left B join on and 後面的條件來使查出的兩條記錄變成一條,奈何發現還是有兩條。 後來發現 join on and 不會過濾結果記錄條數,只會根據and後的條件是否顯示 B表的記錄,A表的記錄一定會顯示。 不管and 後面的是A.id=1還是B.id=1, ...
  • 1、項目結構 項目說明: 該項目是用NET6搭建的webapi介面項目,然後配一個asp.net mvc的管理系統,資料庫是用的mysql,在SiteApi項目下有資料庫sql文件,下麵是一些截圖 介面配置的swagger界面 配套的後臺管理系統 項目具體說明: SiteApi:NET6介面項目,具 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...