欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot定時任務備份mysql數(shù)據(jù)庫的實現(xiàn)示例

 更新時間:2024年03月03日 11:52:52   作者:小飛俠在嗎  
為了防止數(shù)據(jù)庫被清庫或者誤刪數(shù)據(jù)庫的情況,所以需要定時將mysql數(shù)據(jù)庫中的數(shù)據(jù)進行備份,本文主要介紹了springboot定時任務備份mysql數(shù)據(jù)庫的實現(xiàn)示例,需要的朋友們下面隨著小編來一起學習學習吧

記錄在Linux 系統(tǒng)上定時備份MySQL數(shù)據(jù)庫

1、在代碼中添加備份

package org.jeecg.modules.xczxhhr.job;

import lombok.extern.slf4j.Slf4j;
import org.quartz.Job;
import org.quartz.JobExecutionContext;

import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.concurrent.TimeUnit;
@Slf4j
public class SyncDatabaseBackupJob implements Job {
    @Override
    public void execute(JobExecutionContext jobExecutionContext) {
        String mysqlUser = "root";
        String mysqlPassword = "你的密碼";
        String dbname = "你的數(shù)據(jù)庫名字";
        String backupDir = "備份文件存儲地址";

        int expireDays = 15;

        String backupTime = new SimpleDateFormat("yyyyMMddHHmm").format(new Date());
        String backupFileName = dbname + "-" + backupTime + ".sql";

        String[] command = new String[]{"mysqldump", "-u" + mysqlUser, "-B", dbname};

        ProcessBuilder processBuilder = new ProcessBuilder(command);
        processBuilder.environment().put("MYSQL_PWD", mysqlPassword);

        File backupFile = new File(backupDir, backupFileName);
        processBuilder.redirectOutput(backupFile);

        try {
            Process process = processBuilder.start();
            int exitStatus = process.waitFor();

            if (exitStatus == 0) {
                // 備份成功,可以繼續(xù)實現(xiàn)刪除過期備份的邏輯
                log.info("數(shù)據(jù)庫備份成功");
                cleanupOldBackups(backupDir, expireDays);
            } else {
                // 備份失敗,可以記錄日志或者進行其他處理
                log.error("數(shù)據(jù)庫備份失敗:" + exitStatus);
                // 輸出錯誤信息
                BufferedReader errorReader = new BufferedReader(new InputStreamReader(process.getErrorStream()));
                String line;
                while ((line = errorReader.readLine()) != null) {
                    log.error(line);
                }
            }
        } catch (IOException | InterruptedException e) {
            // 異常處理
            e.printStackTrace();
            log.error("備份數(shù)據(jù)庫出現(xiàn)異常:" + e.getMessage());
        }
    }

    private void cleanupOldBackups(String backupDir, int expireDays) {
        File dir = new File(backupDir);
        File[] files = dir.listFiles();

        if (files != null) {
            for (File file : files) {
                long diffInMillies = System.currentTimeMillis() - file.lastModified();
                long diffInDays = TimeUnit.DAYS.convert(diffInMillies, TimeUnit.MILLISECONDS);

                if (diffInDays > expireDays) {
                    if (file.delete()) {
                        log.info("已刪除舊備份文件:" + file.getName());
                    } else {
                        log.info("未能刪除舊備份文件:"+ file.getName());
                    }
                }
            }
        }
    }
}

2、也可以在Linux中執(zhí)行備份腳本,backup_script.sh,內(nèi)容如下:

#!/bin/bash
# 設置mysql的登錄用戶名和密碼(根據(jù)實際情況填寫)
mysqlUser="root"
mysqlPassword="密碼"
dbname='數(shù)據(jù)庫名字'

# 備份文件存放地址(根據(jù)實際情況填寫)
backup_dir=/data/depFile/bakdb

# 判斷目錄是不是已經(jīng)存在,如果不存在則創(chuàng)建
if [ ! -d $backup_dir ]; then
  mkdir -p $backup_dir
fi
#===================================
# 是否刪除過期數(shù)據(jù)
expire_backup_delete="ON"
expire_days=15
backup_time=$(date +%Y%m%d%H%M)
welcome_msg="Welcome to use MySQL backup tools!"
#===========================================
# 備份指定數(shù)據(jù)庫中數(shù)據(jù)(此處假設數(shù)據(jù)庫是mysql_backup_test)
mysqldump -u$mysqlUser -p$mysqlPassword -B $dbname >$backup_dir/$dbname-$backup_time.sql

#刪除過期數(shù)據(jù)
if [ "$expire_backup_delete" == "ON" -a "$backup_dir" != "" ]; then
  # $(find $backup_dir/ -type f -mtime +$expire_days | xargs rm -rf)
  find $backup_dir/ -type f -mtime +$expire_days -exec rm -f {} \;
  echo "Expired backup data delete complete!"
fi

接下來,你需要設置一個定時任務,讓這個腳本在每天凌晨一點執(zhí)行。你可以使用 cron 來實現(xiàn)這一點。

首先,打開終端并輸入以下命令來編輯 crontab 文件:

crontab -e

然后,在 crontab 文件中添加以下行來設置定時任務:

0 1 * * * /bin/bash /path/to/your/backup_script.sh

在這個例子中,/path/to/your/backup_script.sh 應該替換為你實際的備份腳本所在的路徑。

保存并退出編輯器,這樣就設置好了定時任務。這個任務將會在每天凌晨一點執(zhí)行你的備份腳本

到此這篇關于springboot定時任務備份mysql數(shù)據(jù)庫的實現(xiàn)示例的文章就介紹到這了,更多相關springboot定時備份mysql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java Calendar類的使用總結(jié)實例

    Java Calendar類的使用總結(jié)實例

    這篇文章主要介紹了Java Calendar類的使用總結(jié)實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • Spring Boot構(gòu)建系統(tǒng)安全層的步驟

    Spring Boot構(gòu)建系統(tǒng)安全層的步驟

    這篇文章主要介紹了Spring Boot構(gòu)建系統(tǒng)安全層的步驟,幫助大家更好的理解和學習使用Spring Boot框架,感興趣的朋友可以了解下
    2021-04-04
  • Spring空值和特殊字符的注入方式

    Spring空值和特殊字符的注入方式

    文章介紹了如何通過創(chuàng)建類、配置文件和測試代碼來實現(xiàn)空值和特殊字符注入,具體包括定義屬性、生成set方法、配置對象創(chuàng)建和屬性注入、以及編寫測試代碼進行驗證
    2024-11-11
  • 一文教會你如何從0到1搭建一個SpringBoot項目

    一文教會你如何從0到1搭建一個SpringBoot項目

    今天剛好學習到SpringBoot,就順便記錄一下吧,下面這篇文章主要給大家介紹了關于如何從0到1搭建一個SpringBoot項目的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2024-01-01
  • 關于Java跨域Json字符轉(zhuǎn)類對象的方法示例

    關于Java跨域Json字符轉(zhuǎn)類對象的方法示例

    這篇文章主要給大家介紹了關于Java跨域Json字符轉(zhuǎn)類對象的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • SpringBoot整合Java DL4J實現(xiàn)情感分析系統(tǒng)

    SpringBoot整合Java DL4J實現(xiàn)情感分析系統(tǒng)

    在當今數(shù)字化時代,企業(yè)越來越重視用戶的反饋,以不斷改進產(chǎn)品和服務,自然語言處理技術為分析用戶評價提供了強大的工具,本文將介紹如何使用 Spring Boot 整合 Java Deeplearning4j 構(gòu)建一個情感分析系統(tǒng),需要的朋友可以參考下
    2024-10-10
  • Java 十大排序算法之插入排序刨析

    Java 十大排序算法之插入排序刨析

    插入排序(InsertionSort),一般也被稱為直接插入排序。對于少量元素的排序,它是一個有效的算法。插入排序是一種最簡單的排序方法,它的基本思想是將一個記錄插入到已經(jīng)排好序的有序表中,從而一個新的、記錄數(shù)增 1 的有序表
    2021-11-11
  • Linux centos7環(huán)境下jdk安裝教程

    Linux centos7環(huán)境下jdk安裝教程

    這篇文章主要為大家詳細介紹了Linux centos7環(huán)境下jdk的安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Java多線程Semaphore工具的使用詳解

    Java多線程Semaphore工具的使用詳解

    Semaphore 是一種用于控制線程并發(fā)訪問數(shù)的同步工具。它通過維護一定數(shù)量的許可證來限制對共享資源的訪問,許可證的數(shù)量就是可以同時訪問共享資源的線程數(shù)目,需要的朋友可以參考下
    2023-05-05
  • SpringBoot請求參數(shù)相關注解說明小結(jié)

    SpringBoot請求參數(shù)相關注解說明小結(jié)

    這篇文章主要介紹了SpringBoot請求參數(shù)相關注解說明,主要包括@PathVariable,@RequestHeader、@CookieValue、@RequestBody和@RequestParam,本文結(jié)合實例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2022-05-05

最新評論