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查看定时任务

相关推荐
爱学习的小囧2 小时前
ESXi 8.0 原生支持 NVMe 固态硬盘吗?VMD 配置详解教程
linux·运维·服务器·esxi·esxi8.0
NCIN EXPE2 小时前
redis 使用
数据库·redis·缓存
MongoDB 数据平台2 小时前
为编码代理引入 MongoDB 代理技能和插件
数据库·mongodb
极客on之路2 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家2 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE2 小时前
开启mysql的binlog日志
数据库·mysql
坚持就完事了2 小时前
Linux中的变量
linux·运维·服务器
yejqvow123 小时前
CSS如何控制placeholder文字的颜色_使用--placeholder伪元素
jvm·数据库·python
handler013 小时前
从源码到二进制:深度拆解 Linux 下 C 程序的编译与链接全流程
linux·c语言·开发语言·c++·笔记·学习
oLLI PILO3 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库