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'"
使用方式

直接使用
在这里插入图片描述
可能会提示 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. 定时备份mysql数据库

    2023-12-28 04:44:02       13 阅读
  2. entos定时自动备份mysql

    2023-12-28 04:44:02       35 阅读
  3. Linux 定时任务备份MySQL数据库

    2023-12-28 04:44:02       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-28 04:44:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-28 04:44:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-28 04:44:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-28 04:44:02       18 阅读

热门阅读

  1. leetCode算法—15. 三数之和

    2023-12-28 04:44:02       32 阅读
  2. 工厂方法模式(Factory Method)

    2023-12-28 04:44:02       36 阅读
  3. uniapp ios input disabled为true时 无法左右滚动

    2023-12-28 04:44:02       30 阅读