linux 自动备份数据库脚本

本文介绍了在Linux系统下进行MySQL数据库备份的方法。通过使用mysqldump命令编写备份脚本,可实现单个数据库备份,并设置只保留15天的备份文件。同时,说明了脚本测试时可能遇到的问题及解决办法,最后利用crontab定时执行备份脚本。

方法概述

  1. 使用mysqldump命令编写备份脚本;
  2. 使用crontab定时执行备份脚本。

编写备份脚本: 

 

# !/bin/bash
# 定义属性

MYSQL_USER="root" 
MYSQL_PASSWORD="root"

# 名称:mysqlbak.sh
# 本地存放备份数据库目录
backupdir=/data/backups/mysqlbak
# 如果文件夹不存在,创建文件夹
if [ ! -d $backupdir ]; then
  mkdir -p $backupdir
  echo -e "备份目录 $backupdir 创建成功。"
else
  echo "备份目录 $backupdir 已经存在。"
fi
 
# 备份文件后缀时间
time="$(date +%Y%m%d_%H%M%S)" 
 
echo "开始备份数据库..."
 
# 注意数据库备份密码 设置在/etc/my.cnf中
# 备份所有数据库到本地(不压缩)
# echo '/data/mysql8/bin/mysqldump --opt --all-databases > $backupdir/all_$time.sql'
# 压缩
#/data/mysql8/bin/mysqldump --opt --all-databases | gzip >  $backupdir/all_$time.sql.gz

# 备份单个数据库(不压缩)
 /data/local/mysql/bin/mysqldump -u${MYSQL_USER} -p${MYSQL_PASSWORD} --databases test > $backupdir/test_$time.sql
 
echo "备份数据完成。"
 

 
# 只保留15天的备份文件
find $backupdir -name "test_*.sql" -type f -mtime +15 -exec rm -rf {} \; > /dev/null 2>&1
echo "删除备份成功。"

 测试脚本 

1、Linux上直接运行脚本

./backup_mysql.sh 

2.报-bash: ./backup_mysql.sh: Permission denied      

# 修改脚本权限
chmod 777 backup_mysql.sh


 3.报mysqldump: command not found
 

  1. # 1.寻找mysqldump

  2. find / -name mysqldump

  3. # 2.建立软连接(/usr/local/mysql/bin/mysqldump 是上一步的结果)

  4. ln -s /usr/local/mysql/bin/mysqldump /usr/bin

 

定时执行脚本:

设置定时执行脚本(每天 00:00 执行脚本)

 

  1. #1. 以编辑模式打开个人的crontab配置文件

  2. crontab –e

  3. #2. 加入一下这行:

  4. 0 0 * * * /home/shell/XXXXXXXX.sh

  5. #3. 重载配置

  6. service crond reload

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值