mysql熱備腳本

来源:https://www.cnblogs.com/xiaoyafei/archive/2018/04/13/8822110.html
-Advertisement-
Play Games

#!/bin/bash #mysql熱備腳本 #備份策略:每周一進行完整備份,以後每一天在前一天的基礎上進行增量備份 # #備份目錄 back_dir="/data/backup/mysql" #備份資料庫信息 host="" dbuser="" dbpasswd="" #日誌文件 back_log... ...


#!/bin/bash
#mysql熱備腳本
#備份策略:每周一進行完整備份,以後每一天在前一天的基礎上進行增量備份
#
#備份目錄
back_dir="/data/backup/mysql"
#備份資料庫信息
host=""
dbuser=""
dbpasswd=""
 
#日誌文件
back_log="${back_dir}/log/mysql_back.log"
 
#week day
week_day=`date +%w`
#yesterday
yesterday=`date +%F -d "1 days ago"`
 
#日誌記錄函數
function log(){
  echo "`date` $1" | tee -a ${back_log}
}

#判斷當前日期,是周一進行全備份,其他時間進行增量備份
if [ ${week_day} -eq 1 ]; then
#完整備份
  log "周${week_day}開始完全備份..."
  innobackupex --defaults-file=/etc/my.cnf --host=${host} --user=${dbuser} --password=${dbpasswd} ${back_dir} &>> ${back_log}
  if [ $? -eq 0 ]; then
    log "完全備份完畢."
    else
       log "完全備份出錯,請檢查."
       exit 1
  fi
  else
    let dir_num=`find ${back_dir} -type d -name "${yesterday}*" | wc -l`
    if [ ${dir_num} -ne 1 ]; then
      log "昨天增量目錄未找到或昨天備份目錄大於等於2個,請確認後再次備份."
      exit 1
    fi
    incremental_dir=`find ${back_dir} -type d -name "${yesterday}*"`
    log "周${week_day}開始增量備份..."
    #增量備份
    innobackupex --host=${host} --user=${dbuser} --password=${dbpasswd} --incremental ${back_dir} --incremental-basedir=${incremental_dir} &>> ${back_log}
    if [ $? -eq 0 ]; then
      log "增量備份成功."
      else
        log "備份失敗,請檢查日誌..."
        exit 1
    fi
fi
exit $?

 


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

-Advertisement-
Play Games
更多相關文章
  • 推薦 C#參考教程 http://www.csref.cn ...
  • 以下為一個合併學生分數的示例數據,依據主鍵統計各個學生的總分數 拿到這種數據,如果要將數據合併,常規的做法就是通過遍歷實現,代碼簡單也容易理解 不考慮代碼行數為工作績效的情況下,可以通過Linq或擴展方法一行優雅的搞定 通過GroupBy過濾主鍵去掉重覆項,避免ToDictionary時重覆主鍵異常 ...
  • 有時候我們需要對數據表進行篩選,微軟為我們封裝了一個公共方法, DataTable.Select(),其用法如下: Select() Select(string filterExpression) Select(string filterExpression, string sort) Select ...
  • 阿裡雲官方的skd(aliyun-net-sdk-core,aliyun-net-sdk-dysmsapi)在dnc中發送簡訊會出錯,nuget上的包貌似也一樣不管用。直接改下sdk當然也可以,但就發個簡訊,官方的sdk實在是有點繁雜,其實可以簡單化,一個類就搞定。 SmsObject.cs 調用方 ...
  • .NET Core2.0+MVC 用Redis/Memory+cookie實現的sso單點登錄 ...
  • Smobiler是什麼——Smobiler是一個在Visual Studio上開發APP的平臺,語言:C#、VB ...
  • 演算法描述 1.由數組第一位數值開始與相鄰數值進行比較,每次將比較後大的數值後移。最後將會把數組中最大值移動到數組最後; 2.依次對數組中未排序序列重覆進行比較排序,將比較後的最大值移動到未排序序列的最後; 代碼實現 完整代碼 ...
  • Shell是一種應用程式,提供一個界面訪問操作系統內核的服務. 1:編寫shell腳本 vi test.sh #!/bin/bash #指定這個腳本需要什麼解釋器來執行 echo "Hello World !" # echo命令用於向視窗輸出文本 2:執行shell腳本 cd入文件存在的目錄 chm ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...