記錄在Linux 系統上定時備份MySQL數據庫
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 {@Overridepublic void execute(JobExecutionContext jobExecutionContext) {String mysqlUser = "root";String mysqlPassword = "你的密碼";String dbname = "你的數據庫名字";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) {// 備份成功,可以繼續實現刪除過期備份的邏輯log.info("數據庫備份成功");cleanupOldBackups(backupDir, expireDays);} else {// 備份失敗,可以記錄日志或者進行其他處理log.error("數據庫備份失敗:" + 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("備份數據庫出現異常:" + 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中執行備份腳本,backup_script
.sh,內容如下:
#!/bin/bash
# 設置mysql的登錄用戶名和密碼(根據實際情況填寫)
mysqlUser="root"
mysqlPassword="密碼"
dbname='數據庫名字'# 備份文件存放地址(根據實際情況填寫)
backup_dir=/data/depFile/bakdb# 判斷目錄是不是已經存在,如果不存在則創建
if [ ! -d $backup_dir ]; thenmkdir -p $backup_dir
fi
#===================================
# 是否刪除過期數據
expire_backup_delete="ON"
expire_days=15
backup_time=$(date +%Y%m%d%H%M)
welcome_msg="Welcome to use MySQL backup tools!"
#===========================================
# 備份指定數據庫中數據(此處假設數據庫是mysql_backup_test)
mysqldump -u$mysqlUser -p$mysqlPassword -B $dbname >$backup_dir/$dbname-$backup_time.sql#刪除過期數據
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
接下來,你需要設置一個定時任務,讓這個腳本在每天凌晨一點執行。你可以使用 cron 來實現這一點。
首先,打開終端并輸入以下命令來編輯 crontab 文件:
crontab -e
然后,在 crontab 文件中添加以下行來設置定時任務:
0 1 * * * /bin/bash /path/to/your/backup_script.sh
在這個例子中,/path/to/your/backup_script.sh
應該替換為你實際的備份腳本所在的路徑。
保存并退出編輯器,這樣就設置好了定時任務。這個任務將會在每天凌晨一點執行你的備份腳本