linux定时备份数据库sql文件(表格、视图、存储过程,已保存的查询语句不会被备份)

创建一个脚本文件xxx.sh

为其设置全部权限chmod +777 xxx.sh

bash 复制代码
#!/bin/bash  

# 设置备份目录和文件名 
current_time=$(date "+%Y%m%d_%H%M%S")
backup_dir="/root/db_back/db"
backup_file="$backup_dir/db_ship_backup_$current_time.sql"
log_file="/usr/local/software/ship/dbbak/dblog.log"


# MySQL数据库连接参数  
db_host="xx.xx.xx.xx"
db_port="3306"
db_user="root"
db_password="xxxxxx"
db_name="xxxx"

# 创建备份目录(如果不存在)  
mkdir -p "$backup_dir"
# 提取文件的父目录
dir_path=$(dirname "$log_file")
# 使用mkdir -p创建父目录
mkdir -p "$dir_path"
# 使用touch创建文件
touch "$log_file"
#判断数据库是否在正常运行
mysqladmin -h "$db_host" -P "$db_port" -u $db_user -p$db_password ping
# 根据mysqladmin命令的退出状态判断MySQL服务器是否正常运行
if [ $? -eq 0 ]; then
    echo "MySQL服务器正在运行" >> $log_file
    # 使用mysqldump命令备份数据库
    mysqldump -u "$db_user" -p$db_password --routines --triggers "$db_name" > "$backup_file"
    # 检查备份是否成功  
    if [ $? -eq 0 ]; then
      echo "【$current_time】数据库备份成功!备份文件:$backup_file"  >> $log_file
    else
      echo "【$current_time】数据库备份失败!"  >> $log_file
    fi
else
    echo "【$current_time】MySQL服务器未运行或无法访问" >> $log_file

在定时文件中添加该定时任务(每天0点定时执行,执行结果打印在log文件中)
cretab -e
0 0 * * * /xxx.sh

使用crontab -l查看定时任务

相关推荐
python在学ing6 小时前
Django框架学习笔记:从零基础到项目实战
数据库·python·django·sqlite
s_w.h6 小时前
【 linux 】文件系统
linux·运维·服务器·算法·bash
duoduo_sing7 小时前
数据库备份终极方案:从脚本手动到自动化热备+异地同步实战
运维·数据库·自动化·用友
Lao A(zhou liang)的菜园7 小时前
Oracle 增量检查点 & FAST_START_MTTR_TARGET 核心总结
数据库·oracle
都在酒里7 小时前
Linux字符设备驱动开发(七):输入子系统——驱动GPIO按键并上报事件
linux·驱动开发·交互
风曦Kisaki7 小时前
# Linux运维Day06:HAproxy负载均衡(代理调度软件对比)、Tomcat服务部署与LNMJ架构
linux·运维·负载均衡
wbs_scy7 小时前
MySQL 多表连接查询实战:内连接 + 外连接
数据库·mysql
cfm_29147 小时前
MySQL8.0 核心新特性详解(架构/性能/SQL/索引/安全全覆盖)
sql·安全·架构
largecode7 小时前
座机号码认证如何操作?申请热线实名名片,树立统一官方客服形象
linux·sql·华为·c#·.net·wpf·harmonyos
杨云龙UP7 小时前
ODA/Oracle RAC 节点 Load 100+ 排查:一个 lsof 残留进程引发的负载虚高问题 2026-05-27
linux·数据库·oracle·centos·误操作