linux 环境下mysql 数据库自动备份和清库 通过crontab 创建定时任务实现mysql数据库备份

文章目录

  • [1. 需求](#1. 需求)
  • [2.shell 脚本编写](#2.shell 脚本编写)
  • [3. 通过crontab 创建定时任务](#3. 通过crontab 创建定时任务)

1. 需求

linux 环境下 通过crontab 创建定时任务实现mysql数据库每日凌晨2点备份

2.shell 脚本编写

复制代码
#!/bin/bash
#备份保存路径与保留天数
backup_dir=/usr/local/mysql_bak/mysqlbackup
days=3
dd=$(date +%Y%m%d%H%M%S)

#获取所有非系统数据库
# 安全读取密码(无回显)
read -s -p "Enter MySQL password: " MYSQL_PWD
echo  # 换行

# 执行查询并检查错误
if ! DATABASES=$(mysql -uroot -p"$MYSQL_PWD" -sNe "SHOW DATABASES" 2>/dev/null); then
    echo "Error: Failed to connect to MySQL or execute query." >&2
    exit 1
fi

# 使用示例
echo "Databases:"
echo "$DATABASES"

#DATABASES=$(mysql  --defaults-file=/etc/my.cnf -s -e "SHOW DATABASES")
for db in $DATABASES; do
        if [[ $db != "information_schema" ]] && [[ $db != "performance_schema" ]] &&[[ $db != "mysql" ]]&&[[  $db != "sys" ]]; then
                #执行备份并压缩
                mysqldump --skip-lock-tables $db |gzip >$backup_dir/${db}_$dd.sql.gz
                #清理旧备份
                ls -lt $backup_dir/${db}_* | awk 'NR>'$days | xargs rm -f
        fi
done


==========================优化后1======================
#!/bin/bash
#备份保存路径与保留天数
backup_dir=/usr/local/mysql_bak/mysqlbackup
#日期路径
day_dir=$(date +%Y-%m-%d)
days=3
dd=$(date +%Y%m%d%H%M%S)

#获取所有非系统数据库
# 安全读取密码(无回显)
read -s -p "Enter MySQL password: " MYSQL_PWD
echo  # 换行

# 执行查询并检查错误
if ! DATABASES=$(mysql -uroot -p"$MYSQL_PWD" -sNe "SHOW DATABASES" 2>/dev/null); then
    echo "Error: Failed to connect to MySQL or execute query." >&2
    exit 1
fi

# 使用示例
echo "Databases:"
echo "$DATABASES"
cd $backup_dir
#DATABASES=$(mysql  --defaults-file=/etc/my.cnf -s -e "SHOW DATABASES")
for db in $DATABASES; do
        if [[ $db != "information_schema" ]] && [[ $db != "performance_schema" ]] &&[[ $db != "mysql" ]]&&[[  $db != "sys" ]] ; then
                if [[ ! -e $day_dir  ]]; then
                mkdir $day_dir
                fi
                #执行备份并压缩
                mysqldump --skip-lock-tables $db |gzip >$backup_dir/$day_dir/${db}_$dd.sql.gz
                #清理旧备份
                ls -lt $backup_dir/${db}_* | awk 'NR>'$days | xargs rm -f
        fi
done

==============================优化后2============================
#!/bin/bash
#备份保存路径与保留天数
backup_dir=/usr/local/mysql_bak/mysqlbackup
#日期路径
day_dir=$(date +%Y-%m-%d)
days=7
dd=$(date +%Y%m%d%H%M%S)

MYSQL_PWD=root123
echo  # 换行

# 执行查询并检查错误
if ! DATABASES=$(mysql -uroot -p"$MYSQL_PWD" -sNe "SHOW DATABASES" 2>/dev/null); then
    echo "Error: Failed to connect to MySQL or execute query." >&2
    exit 1
fi

# 使用示例
echo "Databases:"
echo "$DATABASES"
cd $backup_dir
#DATABASES=$(mysql  --defaults-file=/etc/my.cnf -s -e "SHOW DATABASES")
for db in $DATABASES; do
        if [[ $db != "information_schema" ]] && [[ $db != "performance_schema" ]] &&[[ $db != "mysql" ]]&&[[  $db != "sys" ]] ; then
                if [[ ! -e $day_dir  ]]; then
                mkdir $day_dir
                fi
                #执行备份并压缩
                mysqldump --skip-lock-tables $db |gzip >$backup_dir/$day_dir/${db}_$dd.sql.gz
                #清理旧备份
                ls -lt $backup_dir/${db}_* | awk 'NR>'$days | xargs rm -f
        fi
done

3. 通过crontab 创建定时任务

  1. crontab -l 查询定时任务列表

  2. crontab -e 编辑定时任务

    配置crontab每日执行(如凌晨2点)脚本如下:
    0 2 * * * /usr/local/mysql_bak/mysql_backup_all.sh >>/var/log/mysql_backup.log 2>&1

  1. 通过vim 保存退出。

  2. 给脚本赋权限

    chmod 700 mysql_backup_all.sh

  3. 再执行crontab -l 查询是否生效。

相关推荐
思成不止于此1 天前
【MySQL 零基础入门】MySQL 约束精讲(一):基础约束篇
数据库·笔记·sql·学习·mysql
ActionTech1 天前
SCALE | SQLFlash 在 SQL 优化维度上的表现评估
数据库·sql
老华带你飞1 天前
建筑材料管理|基于springboot 建筑材料管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习·spring
Kira Skyler1 天前
ELF文件解析 elf.o 文件主要内容.md
linux
逐梦吧!旅行者1 天前
Linux MySQL 5.7用户管理与用户密码的设置问题
linux·mysql
RisunJan1 天前
Linux命令-grpck命令(验证和修复组配置文件(`/etc/group` 和 `/etc/gshadow`)完整性的工具)
linux·运维·服务器
loosed1 天前
Ubuntu mysql8 tar.xz 安装
linux·ubuntu·adb
Xの哲學1 天前
Linux VxLAN深度解析: 从数据平面到内核实现的全面剖析
linux·服务器·算法·架构·边缘计算
NaiLuo_451 天前
MySQL基本查询
数据库·mysql
刺客xs1 天前
MYSQL数据库------多表查询
数据库·mysql