MySQL(77)如何設置自動備份任務?

設置自動備份任務可以確保你的數據庫定期備份,防止數據丟失。以下是如何使用 Bash 腳本和 Cron 任務在 Linux 系統上設置 MySQL 數據庫的自動備份任務的詳細步驟和代碼示例。

1. 編寫備份腳本

首先,我們需要編寫一個備份腳本。這個腳本將包含執行備份的所有步驟。

1.1 創建并編輯備份腳本

創建一個名為 backup.sh 的腳本文件:

nano /path/to/backup.sh

添加以下內容到腳本文件中:

#!/bin/bash# 配置參數
DB_USER="root"
DB_PASSWORD="yourpassword"
BACKUP_DIR="/path/to/backups"
DATE=$(date +\%F_\%T)
FULL_BACKUP_IMAGE="$BACKUP_DIR/full_backup_$DATE.bak"
INCREMENTAL_BACKUP_IMAGE="$BACKUP_DIR/incremental_backup_$DATE.bak"# 檢查是否需要完全備份
if [ ! -d "$BACKUP_DIR/full_backup" ] || [ -z "$(ls -A $BACKUP_DIR/full_backup)" ]; then# 執行完全備份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --backup-dir=$BACKUP_DIR/full_backup --backup-image=$FULL_BACKUP_IMAGE backup-to-image
else# 執行增量備份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --incremental --incremental-base=history:last_backup --backup-dir=$BACKUP_DIR/incremental_backup --backup-image=$INCREMENTAL_BACKUP_IMAGE backup-to-image
fi# 檢查備份是否成功
if [ $? -eq 0 ]; thenecho "Backup successful: $FULL_BACKUP_IMAGE or $INCREMENTAL_BACKUP_IMAGE"
elseecho "Backup failed"exit 1
fiexit 0
1.2 給予腳本執行權限
chmod +x /path/to/backup.sh

2. 設置 Cron 任務

Cron 是一個 Unix 類操作系統的任務調度程序,用于在特定時間自動執行任務。我們將使用 Cron 來定時執行備份腳本。

2.1 編輯 Cron 表

打開 Cron 表進行編輯:

crontab -e
2.2 添加 Cron 任務

添加如下條目,例如每天凌晨 2 點執行備份:

0 2 * * * /path/to/backup.sh

這條命令的含義是每天凌晨 2 點執行 /path/to/backup.sh 腳本。Cron 表的格式如下:

* * * * * command
- - - - -
| | | | |
| | | | +----- day of week (0 - 7) (Sunday=0 or 7)
| | | +------- month (1 - 12)
| | +--------- day of month (1 - 31)
| +----------- hour (0 - 23)
+------------- minute (0 - 59)

3. 備份腳本細節

為了更詳細地展示備份腳本的內容,這里進一步解釋每一部分的作用。

3.1 配置參數

在腳本開頭定義一些變量,包括數據庫用戶名、密碼、備份目錄和備份文件名:

DB_USER="root"
DB_PASSWORD="yourpassword"
BACKUP_DIR="/path/to/backups"
DATE=$(date +\%F_\%T)
FULL_BACKUP_IMAGE="$BACKUP_DIR/full_backup_$DATE.bak"
INCREMENTAL_BACKUP_IMAGE="$BACKUP_DIR/incremental_backup_$DATE.bak"
3.2 檢查并執行備份

腳本檢查是否存在一個完全備份目錄以及是否為空。如果沒有完全備份,腳本將執行完全備份。否則,它將執行增量備份:

if [ ! -d "$BACKUP_DIR/full_backup" ] || [ -z "$(ls -A $BACKUP_DIR/full_backup)" ]; then# 執行完全備份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --backup-dir=$BACKUP_DIR/full_backup --backup-image=$FULL_BACKUP_IMAGE backup-to-image
else# 執行增量備份mysqlbackup --user=$DB_USER --password=$DB_PASSWORD --incremental --incremental-base=history:last_backup --backup-dir=$BACKUP_DIR/incremental_backup --backup-image=$INCREMENTAL_BACKUP_IMAGE backup-to-image
fi
3.3 檢查備份是否成功

腳本檢查備份命令的退出狀態碼。如果備份成功,退出碼為 0,腳本將顯示成功消息,否則顯示失敗消息:

if [ $? -eq 0 ]; thenecho "Backup successful: $FULL_BACKUP_IMAGE or $INCREMENTAL_BACKUP_IMAGE"
elseecho "Backup failed"exit 1
fiexit 0

4. 驗證自動備份任務

4.1 查看 Cron 任務

你可以使用以下命令查看當前用戶的 Cron 任務:

crontab -l
4.2 檢查備份文件

在第一次備份任務運行之后,檢查備份目錄 /path/to/backups,確保生成了備份文件。

5. 恢復備份

無論是自動備份還是手動備份,恢復步驟基本相同。

5.1 恢復完全備份
  1. 停止 MySQL 服務:

    sudo systemctl stop mysql
    
  2. 恢復完全備份:

    mysqlbackup --user=root --password=yourpassword --backup-dir=/path/to/backups/full_backup --backup-image=/path/to/backups/full_backup/full_backup_<date>.bak copy-back-and-apply-log
    
  3. 啟動 MySQL 服務:

    sudo systemctl start mysql
    
5.2 恢復增量備份

恢復完全備份后,按順序恢復每個增量備份:

  1. 停止 MySQL 服務:

    sudo systemctl stop mysql
    
  2. 恢復完全備份:

    mysqlbackup --user=root --password=yourpassword --backup-dir=/path/to/backups/full_backup --backup-image=/path/to/backups/full_backup/full_backup_<date>.bak copy-back-and-apply-log
    
  3. 恢復增量備份:

    mysqlbackup --user=root --password=yourpassword --incremental --backup-dir=/path/to/backups/incremental_backup --backup-image=/path/to/backups/incremental_backup/incremental_backup_<date>.bak apply-incremental-backup
    
  4. 啟動 MySQL 服務:

    sudo systemctl start mysql
    

小結

通過編寫備份腳本并使用 Cron 任務定時執行備份腳本,你可以實現 MySQL 數據庫的自動備份。結合 MySQL Enterprise Backup 工具,可以靈活地進行完全備份和增量備份。定期檢查備份文件并驗證恢復過程是確保數據安全和可恢復性的關鍵。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/84100.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/84100.shtml
英文地址,請注明出處:http://en.pswp.cn/web/84100.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

.NET 開發中全局數據存儲的幾種方式

文章目錄 一、靜態類與靜態成員實現方式特點優缺點 二、應用程序配置系統1. appsettings.json (ASP.NET Core)使用方式2. 用戶設置 (WinForms/WPF)特點 三、依賴注入容器ASP.NET Core 示例特點 四、內存緩存 (IMemoryCache)實現方式特點 五、分布式緩存 (IDistributedCache)實現…

人才爭奪戰關鍵期,AI如何賦能招聘效率倍增、精準選拔

數智化轉型浪潮席卷全球的今天&#xff0c;人才作為企業核心競爭力的地位日益凸顯。而在傳統招聘流程&#xff0c;尤其是面試環節正面臨效率瓶頸、體驗短板等多項挑戰&#xff0c;典型如&#xff1a; 耗時冗長的篩選與安排&#xff1b;難以避免的主觀評價偏差&#xff1b;海量…

介紹下分布式ID的技術實現及應用場景

什么是分布式ID 分布式ID是指在分布式系統中生成的特定范圍內唯一的標識符&#xff0c;如訂單號、商品ID、鏈路追蹤TraceID。 隨著業務發展&#xff0c;對分布式ID的要求越來越高&#xff0c;其中最基本的要求如下 全局唯一&#xff1a;在任何節點、任何時間生成的ID都必須是…

【leetcode-字母異位詞分組】

排序法 public List<List<String>> groupAnagrams(String[] strs) {//最終值List<List<String>> result new ArrayList<>();//排序法HashMap<String,List<String>> map new HashMap<>(); //遍歷strfor(String str : strs){/…

langchain從入門到精通(九)——ChatGPT/Playground手動模擬記憶功能

1. 摘要緩沖混合記憶 摘要緩沖混合記憶中&#xff0c;所需的模塊有&#xff1a; chat_message_history&#xff1a;存儲歷史消息列表。moving_summary_buffer&#xff1a;移除消息的匯總字符串。summary_llm&#xff1a;生成摘要的 LLM&#xff0c;接收 summary&#xff08;當…

docker單點安裝Hadoop

1、Docker中拉取jdk8鏡像 拉取鏡像 docker pull openjdk:8-jdk 查看jdk docker run -it openjdk:8-jdk bash which java 2、安裝ubuntu源 拉取鏡像 docker pull ubuntu:22.04 保存 docker save -o ubuntu-22.04.tar.gz ubuntu:22.04 移動到自己想要的目錄 mv /roo…

uniapp項目之小兔鮮兒小程序商城(二) 首頁的實現:自定義導航欄,輪撥圖,前臺分類,熱門推薦,猜你喜歡,下拉刷新,骨架屏

文章目錄 零.首頁最終效果一.自定義導航欄1.新建pages/index/components/CustomNavbar.vue首頁子組件2.在首頁pages/index/index.vue中引入3.隱藏默認導航欄修改標題顏色4.適配不同機型使用到了uniapp的一個api:獲取屏幕邊界到安全區域的距離在子組件中使用 二.輪撥圖1.新建 sr…

RustDesk自建遠程服務器

目錄 服務端 環境linux 安裝 開放端口 客戶端配置 下載客戶端 安裝后配置網絡 參考&#xff1a;RustDesk自建遠程服務器_rustdesk自建服務器-CSDN博客 服務端 環境 linux 安裝 下載 wget https://github.com/rustdesk/rustdesk-server/releases/download/1.1.8-2/r…

【Axure高保真原型】圖片伸縮展示列表

今天和大家分享圖片伸縮展示列表的3個原型案例&#xff0c;模版都是用中繼器制作的&#xff0c;所以使用也很方便&#xff0c;在中繼器表格里導入對應的圖片&#xff0c;即可自動生成交互效果&#xff0c;具體效果可以點擊下方視頻觀看或打開下方預覽地址查看哦 【原型效果】 …

keil新建工程文件結構和每個文件的作用解析(標準庫版本)

通過網盤分享的文件:STM32工程模板 鏈接:https://pan.baidu.com/s/1YPFgXu1kwuwsCVxrXFSjZg?pwd=1111 提取碼: 1111 --來自百度網盤超級會員v5的分享 這個工程模版是來源于B站江科大的模版,每個人搭建工程文件結構不一樣,僅供參考。 工程文件目錄結構如圖所示 1、DebugC…

【AI論文】Saffron-1:LLM安全保證的推理縮放范例

摘要&#xff1a;現有的安全保證研究主要集中在培訓階段的協調&#xff0c;以向LLM灌輸安全行為。 然而&#xff0c;最近的研究表明這些方法容易受到各種越獄攻擊。 同時&#xff0c;推理擴展顯著提高了LLM推理能力&#xff0c;但在安全保證方面仍未得到探索。 為了解決這一差距…

LLM 支持的基于意圖的分類 網絡釣魚電子郵件

大家讀完覺得有幫助記得關注和點贊&#xff01;&#xff01;&#xff01; 抽象 網絡釣魚攻擊仍然是現代網絡安全的重大威脅&#xff0c;因為它們成功地欺騙了人類和旨在保護他們的防御機制。傳統的檢測系統主要關注用戶在收件箱中看不到的電子郵件元數據。此外&#xff0c;這些…

C++新特性技術發展路徑和時間

C 的新特性發展路徑和時間線是一個持續演進的過程。以下是一個概覽&#xff0c;涵蓋了主要的 C 標準及其關鍵特性&#xff0c;以及它們發布的時間&#xff1a; C 標準版本及發布時間線: C98 (ISO/IEC 14882:1998): 第一個正式的 C 標準。 發布時間: 1998年關鍵特性: 標準模板庫…

OpenAI 如何在激烈的AI人才爭奪戰中搶占先機?

在這個快速發展的人工智能時代&#xff0c;OpenAI 正處于一個至關重要的發展階段。隨著技術的不斷進步&#xff0c;人工智能行業的競爭日益激烈。如何在這場巨大的競爭中立于不敗之地&#xff0c;成為了每一個AI公司的核心挑戰。就在近日&#xff0c;OpenAI 的新招聘主管華金?…

【Java學習筆記】Java繪圖基礎

Java繪圖基礎 一、Java 坐標體系 1. 像素的概念 計算機在屏幕上顯示的內容都是由屏幕上的每一個像素組成的 例如&#xff0c;計算機顯示器的分辨率是 800600&#xff0c;表示計算機屏幕上的每一行由 800 個點組成&#xff0c;共有 600 行&#xff0c;整個計算機屏幕共有 480…

資深Java工程師的面試題目(一)基礎到高級概述

以下是幾道面向資深Java工程師的面試題目&#xff0c;涵蓋了從基礎知識到高級概念及參考答案&#xff1a; 1. Java內存模型和垃圾回收 問題: 請解釋一下Java的內存模型&#xff0c;并描述不同類型的內存區域。如何選擇適合特定應用需求的垃圾收集器&#xff1f;請比較幾種常…

Spring Retry:優雅地實現方法重試機制

前言 在實際的軟件開發中&#xff0c;尤其是在涉及網絡請求、數據庫操作或外部服務調用的場景下&#xff0c;我們常常會遇到一些臨時性故障&#xff08;Transient Failures&#xff09;&#xff0c;例如網絡波動、數據庫連接超時、第三方 API 暫時不可用等。面對這些問題&…

Mysql報錯

1.權限問題 MySQL 認證協議不兼容問題解決方案 這個錯誤表明您的 MySQL 客戶端與服務器要求的認證協議不兼容&#xff0c;通常發生在 MySQL 8.0 服務器與舊版客戶端之間。 nested exception is org.apache.ibatis.exceptions.PersistenceException: Error querying database. …

小米汽車5月交付量超過28000臺,與上月持平

6月1日&#xff0c;小米汽車公布5月交付數據&#xff0c;2025年5月&#xff0c;小米汽車交付量超過28000臺&#xff0c;4月官方披露的交付數據也為28000臺。 此外&#xff0c;小米汽車5月新增29家門店&#xff0c;全國82城已有298家門店&#xff1b;6月計劃新增37家門店&#x…

嚴格一致性模型

SC 的第二點約束 :store 必須被 所有(包括自身)執行流 同時看到 ,但是不要求寫操作“立即”對其他處理器可見&#xff1b;允許寫操作延遲一會兒被其他核觀察到。 而 嚴格一致性模型,包括1. store 必須被 所有(包括自身)執行流 同時看到2. 看到的時間 必須是 某個處理器完成寫操…