创建一个脚本文件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
查看定时任务