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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring Boot構(gòu)建系統(tǒng)安全層的步驟
這篇文章主要介紹了Spring Boot構(gòu)建系統(tǒng)安全層的步驟,幫助大家更好的理解和學習使用Spring Boot框架,感興趣的朋友可以了解下2021-04-04關于Java跨域Json字符轉(zhuǎn)類對象的方法示例
這篇文章主要給大家介紹了關于Java跨域Json字符轉(zhuǎn)類對象的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2017-11-11SpringBoot整合Java DL4J實現(xiàn)情感分析系統(tǒng)
在當今數(shù)字化時代,企業(yè)越來越重視用戶的反饋,以不斷改進產(chǎn)品和服務,自然語言處理技術為分析用戶評價提供了強大的工具,本文將介紹如何使用 Spring Boot 整合 Java Deeplearning4j 構(gòu)建一個情感分析系統(tǒng),需要的朋友可以參考下2024-10-10SpringBoot請求參數(shù)相關注解說明小結(jié)
這篇文章主要介紹了SpringBoot請求參數(shù)相關注解說明,主要包括@PathVariable,@RequestHeader、@CookieValue、@RequestBody和@RequestParam,本文結(jié)合實例代碼給大家講解的非常詳細,需要的朋友可以參考下2022-05-05