MySQL定时备份实现

一、备份数据库

–all-databases 备份所有数据库
/opt/mysqlcopy/all_$(date “+%Y-%m-%d %H:%M:%S”).sql 备份地址

docker exec -it 容器名称 sh -c "mysqldump -u root -p'password' --all-databases > '/opt/mysqlcopy/all_$(date "+%Y-%m-%d %H:%M:%S").sql'"

过滤某个表
–ignore-table=数据库名.表名1 --ignore-table=数据库名.表名2

 #!/bin/bash
docker exec mysql sh -c 'mysqldump -uroot -pKLLJ --ignore-table=iot.dk_eneatic --ignore-table=iot.dk_gwsory iot'  > /home/backupExport/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
使用方式

直接使用
在这里插入图片描述
可能会提示 mysqldump: [Warning] Using a password on the command line interface can be insecure.
意思是密码直接明文显示会不安全,emm~,可以不管

查看备份的文件

进入容器使用 ls -lk 查看
在这里插入图片描述

二、定时备份使用 crontab

安装 crontab
apt update
apt install crontab
检验安装
crontab -V

在这里插入图片描述

新建任务文件

在这里插入图片描述
文件内容如下

#!/bin/bash
docker exec mysql sh -c "mysqldump -u root -p'123456' --all-databases > '/opt/mysqlcopy/all_$(date "+%Y-%m-%d %H:%M:%S").sql'"

新建定时任务

输入命令

crontab -e

在这里插入图片描述

# 表示每2分钟备份一次
*/2 * * * *
# 表示每天凌晨3点备份一次
0 3 * * *
# 表示输出日志
> /opt/cron_output.log 2>&1

编辑完保存退出

三、解决报错

如果没效果,那么就打开/opt/cron_output.log文件看日志

1、/opt/crontab/copyMysql.sh: line 2: $‘\r’: command not found

这是说脚本文件中包含了 Windows 格式的换行符 (\r\n,Carriage Return + Line Feed)。在 Linux 系统中,通常使用 Unix 格式的换行符 (\n,Line Feed)。
解决办法,不要在windows系统里编辑,直接使用vim编辑就行

2、the input device is not a TTY

通常表示脚本试图在一个非交互式(non-interactive)的环境中执行需要交互的命令
解决办法,在你的脚本中,这可能与 docker exec -it 命令有关,该命令通常用于交互式地在容器中执行命令。
去掉 -it 参数,因为在非交互式环境中执行命令时,一般不需要 -it。

四、定期删除多余的备份文件

1、新建文件cleanup_backup.sh

文件内容:

#!/bin/bash

# 定义备份目录和要保留的备份文件数
backup_dir="/home/backup"
num_to_keep=30

# 切换到备份目录
cd "$backup_dir" || exit

# 获取当前目录下的备份文件数
num_backups=$(ls -1 | wc -l)

# 如果备份文件数大于要保留的数量
if [ "$num_backups" -gt "$num_to_keep" ]; then
    # 计算要删除的备份文件数
    num_to_delete=$((num_backups - num_to_keep))

    # 列出备份文件按照修改时间进行排序,并且删除多余的备份文件
    ls -1t | tail -n "$num_to_delete" | xargs -d '\n' rm -f
fi

只需要改
backup_dir=“/home/backup”
num_to_keep=30
再输入

chmod +x cleanup_backup.sh

给文件执行权限
就可以了

2、新增定时任务
crontab -e

按 i 进入编辑模式后追加

0 0 * * * sh /root/******/cleanup_backup.sh

然后按 esc 退出编辑模式后,再按 :wq 保存退出

五、完

  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xl__qd

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值