当前位置: 首页 > news >正文

springboot 定时任务备份mysql数据库

记录在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 应该替换为你实际的备份脚本所在的路径。

保存并退出编辑器,这样就设置好了定时任务。这个任务将会在每天凌晨一点执行你的备份脚本

相关文章:

springboot 定时任务备份mysql数据库

记录在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…...

PMP考试之20240301

1、在回顾项目团队最新的绩效报告时,项目经理注意到他们的产出出现了重大下降。项目经理决定: A.增加每个团队成员在截止日期前完成任务的压力 B.增加状态报告和团队评审会议的频率 C.为表现最好的团队成员提供特别奖励 D.改善和促进团队成员之间的信任和凝聚力…...

什么是MAC地址? win10电脑查看MAC地址的多种方法

您是否知道连接到家庭网络的每件硬件都有自己的身份?正如每个设备都分配有自己的 IP 地址一样,每个硬件都有一个唯一的网络标识符。 该标识符称为MAC 地址。MAC 代表媒体访问控制。您可能需要 MAC 地址来解决网络问题或配置新设备。在 Windows 中查找您…...

vue3中的基本语法

目录 基础素材 vue3的优化 使用CompositionAPI理由 1. reactive() 函数 2. ref() 函数 2.1. ref的使用 2.2. 在 reactive 对象中访问 ref 创建的响应式数据 3. isRef() 函数 4. toRefs() 函数 5. computed() 5.1. 通过 set()、get()方法创建一个可读可写的计算属性 …...

Timeplus-proton流处理器调研

概念 Timeplus是一个流处理器。它提供强大的端到端功能,利用开源流引擎Proton来帮助数据团队快速直观地处理流数据和历史数据,可供各种规模和行业的组织使用。它使数据工程师和平台工程师能够使用 SQL 释放流数据价值。 Timeplus 控制台可以轻松连接到不…...

H3C防火墙安全授权导入

一、防火墙授权概述 前面我们已经了解了一些防火墙的基本概念,有讲过防火墙除了一些基本功能,还有一些高级安全防护,但是这些功能需要另外独立授权,不影响基本使用。这里以H3C防火墙为例进行大概了解下。 正常情况下,防…...

使用 OpenCV 通过 SIFT 算法进行对象跟踪

本文介绍如何使用 SIFT 算法跟踪对象 在当今世界,当涉及到对象检测和跟踪时,深度学习模型是最常用的,但有时传统的计算机视觉技术也可能有效。在本文中,我将尝试使用 SIFT 算法创建一个对象跟踪器。 为什么人们会选择使用传统的计…...

SHELL 脚本: 导出NEO4j DUMP并上传SFTP

前提 开通sftp账号 安装expect 示例 NEO4J_HOME/path/to/neo4j # neo4j 安装目录 DUMP_PATH/data/dump # DUMP本地保存目录 DUMP_FILEneo4j_$(date %F).dump #导出文件名称 UPLOAD_DIR/path/to/stfp/dump/ #上传目录 $NEO4J_HOME/bin/neo4j-admin dump --databaseneo4j --t…...

Vue 封装一个函数,小球原始高度不固定,弹起比例不固定、计算谈几次后,高度低于1米

## 简介 本文将介绍如何使用Vue封装一个函数&#xff0c;计算小球弹跳的次数&#xff0c;直到高度低于1米。函数的参数包括小球的原始高度和弹起比例。通过代码案例演示了如何使用Vue进行封装和调用。 ## 函数封装 vue <template> <div> <label for&qu…...

外地人能申请天津公租房吗?2024天津积分落户租房积分怎么加?

相关推荐&#xff1a;在天津工作的外地人可以申请天津公共租赁住房吗&#xff1f; 外地人可以申请天津公共租赁住房吗&#xff1f; 2024年定居天津租房如何加分&#xff1f; 根据《天津居住证积分指标及积分表》的规定&#xff0c;在天津租房也可以参加积分结算&#xff0c;每…...

毕业设计——基于springboot的聊天系统设计与实现(服务端 + 客户端 + web端)

整个工程包含三个部分&#xff1a; 1、聊天服务器 聊天服务器的职责一句话解释&#xff1a;负责接收所有用户发送的消息&#xff0c;并将消息转发给目标用户。 聊天服务器没有任何界面&#xff0c;但是却是IM中最重要的角色&#xff0c;为表达敬意&#xff0c;必须要给它放个…...

公告栏功能:自动弹出提醒,重要通知不再错过

发布查询时&#xff0c;您是否遇到这样的困扰&#xff1a; 1、查询发布时间未到&#xff0c;学生进入查询主页后发现未发布任何查询&#xff0c;不断进行咨询。 2、有些重要事项需要进入查询主页就进行强提醒&#xff0c;确保人人可见&#xff0c;用户需要反馈“我知道了”才能…...

网络编程学习

思维导图 代码练习 TCP实现通信 服务器端代码 #include <myhead.h> #define SER_IP "192.168.152.135" #define SER_PORT 8910 int main(int argc, const char *argv[]) {//&#xff11;创建用于监听的套接字int sfd -1;sfd socket(AF_INET,SOCK_STREAM,0)…...

centos物理电脑安装过程(2024年1月)

开机时&#xff1a;CtrlAltDelete键重启电脑 重启开始时&#xff1a;按F11&#xff0c;桌面弹出蓝色框&#xff0c;选择第二个SSK SFD142 1.00&#xff0c;回车 选择install centos7安装 选择后弹出选择安装选项&#xff0c;选择语言 连接无线网络 安装设置&#xff0c;选择磁…...

Web自动化测试平台开发---Automated_platform

一、项目简介 历时一个假期&#xff0c;Automated_platform 第一版完工&#xff0c;是一款基于po模式的自动化测试平台,采用后端技术为DjangoceleryRabbitMQmysql 配置mysql数据库&#xff0c;进行数据迁移后&#xff0c;运行项目后&#xff0c;即可成功访问http://127.0.0.1:8…...

mybatis-plus: 多租户隔离机制

文章目录 一、TenantLineHandler1、介绍2、包含的方法 二、简单实例三、实践1、实现TenantLineHandler接口 一、TenantLineHandler 1、介绍 TenantLineHandler 是 Mybatis-Plus 中用于处理多租户的接口&#xff0c;用于实现多租户数据隔离的具体逻辑。通过实现这个接口&#…...

用Socks5代理游戏,绕过“网络海关”去探险

1. 出海大冒险的开始 在游戏世界&#xff0c;就像在现实生活中一样&#xff0c;有时我们需要越过海洋去探索未知的世界。但是&#xff0c;网络上也有一些“海关”&#xff0c;限制我们访问某些网站或游戏服务器。这就是我们今天要克服的挑战&#xff01; 2. Socks5代理&#xf…...

SpringBoot整合rabbitmq-直连队列,没有交换机(一)

说明&#xff1a;本文章只是springboot和rabbitmq的直连整合&#xff0c;只使用队列生产和消费消息&#xff0c;最简单整合&#xff01; 工程图&#xff1a; A.总体pom.xml <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://…...

CUDA C:查看GPU设备信息

相关阅读 CUDA Chttps://blog.csdn.net/weixin_45791458/category_12530616.html?spm1001.2014.3001.5482 了解自己设备的性能是很有必要的&#xff0c;为此CUDA 运行时(runtime)API给用户也提供了一些查询设备信息的函数&#xff0c;下面的函数用于查看GPU设备的一切信息。 …...

深度学习如何入门?——从“小白”到“大牛”的深度学习之旅

大家好&#xff0c;今天我要和大家分享的主题是“深度学习如何入门”。深度学习作为人工智能领域的重要分支&#xff0c;已经取得了许多令人瞩目的成果。然而&#xff0c;对于初学者来说&#xff0c;深度学习可能显得有些神秘和难以入手。那么&#xff0c;如何才能快速入门深度…...

lychee-rerank-mm生产环境部署:支持中英文混合查询的稳定图文匹配服务

lychee-rerank-mm生产环境部署&#xff1a;支持中英文混合查询的稳定图文匹配服务 1. 项目概述与核心价值 lychee-rerank-mm是一个专为RTX 4090显卡优化的多模态图文匹配系统&#xff0c;基于Qwen2.5-VL多模态大模型和Lychee-rerank-mm重排序模型构建。这个系统能够智能分析图…...

从原理到实战:ChameleonUltra开源RFID工具的全栈解析

1. ChameleonUltra是什么&#xff1f;能做什么&#xff1f; 第一次听说ChameleonUltra这个开源项目时&#xff0c;我脑海中浮现的是一只真正的变色龙——它能根据环境改变颜色&#xff0c;完美融入周围。这个比喻意外地贴切&#xff0c;因为ChameleonUltra确实是一款能"变…...

计算机辅助药物设计中的分子对接与虚拟筛选

计算机辅助药物设计中的分子对接与虚拟筛选 在药物研发领域&#xff0c;计算机辅助药物设计&#xff08;CADD&#xff09;已成为加速新药发现的重要工具。其中&#xff0c;分子对接与虚拟筛选技术通过模拟药物分子与靶标蛋白的相互作用&#xff0c;显著提高了候选化合物的筛选…...

实战技巧:AI项目中常用的10个开源工具推荐

模型库的“一站式商店” 大模型应用的“脚手架” RAG系统的“数据管家” Ray&#xff1a;分布式训练的“调度大师” vLLM&#xff1a;大模型推理的“速度之王” Gradio&#xff1a;AI应用的“极速展示台” FastAPI&#xff1a;API服务的“高性能框架” MLflow&#xff1…...

探店无数,平凉这口五仁月饼最难忘

我是浙江人&#xff0c;在广州工作。品质出众次听说五仁月饼是在一个平凉同事嘴里。他形容了半天"外头酥里头软"、"麦香特别浓"、"能撕着吃"&#xff0c;我完全想象不出来——一个饼子能有多特别&#xff1f;直到他寄了一盒给我。探店无数&#…...

STM32F103C8T6最小系统板避坑指南:从Keil5安装到OLED显示,新手必看的10个实战问题

STM32F103C8T6最小系统板避坑指南&#xff1a;从Keil5安装到OLED显示&#xff0c;新手必看的10个实战问题 第一次接触STM32F103C8T6最小系统板时&#xff0c;那种既兴奋又忐忑的心情至今难忘。作为嵌入式开发的经典入门平台&#xff0c;这块蓝色的小板子藏着无数可能性&#xf…...

Rainmeter终极指南:打造高效专业Windows桌面定制平台

Rainmeter终极指南&#xff1a;打造高效专业Windows桌面定制平台 【免费下载链接】rainmeter Desktop customization tool for Windows 项目地址: https://gitcode.com/gh_mirrors/ra/rainmeter Rainmeter作为一款功能强大的Windows桌面定制工具&#xff0c;通过其模块化…...

YOLO26在疲劳驾驶识别中的应用:多类别面部状态检测(项目源码+数据集+模型权重+UI界面+python+深度学习+远程环境部署)

摘要 疲劳驾驶是导致交通事故的重要原因之一&#xff0c;基于视觉的驾驶员状态监测系统对于预防疲劳驾驶具有重要意义。本研究基于YOLO26目标检测算法&#xff0c;构建了一个针对驾驶员面部状态的疲劳识别检测系统。系统共包含4个检测类别&#xff1a;打哈欠(Yawn)、闭眼(clos…...

PPO算法在游戏AI中的实战应用

1. PPO算法为何成为游戏AI的首选 如果你最近在研究游戏AI开发&#xff0c;大概率会频繁听到PPO&#xff08;Proximal Policy Optimization&#xff09;这个名词。作为OpenAI默认的强化学习算法&#xff0c;PPO在《Dota 2》、《星际争霸II》等复杂游戏场景中已经证明了其价值。我…...

Kubernetes StatefulSet 与 Deployment 的区别

Kubernetes作为容器编排领域的核心工具&#xff0c;其资源对象StatefulSet和Deployment常被用于管理应用部署&#xff0c;但两者设计目标截然不同。理解它们的区别&#xff0c;能帮助开发者在有状态服务和无状态服务间做出合理选择。本文将从应用场景、Pod标识、存储管理等方面…...