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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...