当前位置 博文首页 > 昵称已经被占用咯:docker容器内mysql定时任务备份及遇到问题

    昵称已经被占用咯:docker容器内mysql定时任务备份及遇到问题

    作者:[db:作者] 时间:2021-09-15 16:29

    备份mysql

    注:部分为网上找到,后面加以修改。

    创建脚本

    命令:vi mysql_backup.sh
    内容如下:

    #!/bin/bash
    # 设置mysql的登录用户名和密码(根据实际情况填写)
    mysql_user="root"
    mysql_password="123456"
    mysql_host="localhost"
    mysql_port="3306"
    mysql_charset="utf8mb4"
     
    # 备份文件存放地址(根据实际情况填写)
    backup_location=/usr/local
     
    # 是否删除过期数据
    expire_backup_delete="ON"
    expire_days=7
    backup_time=`date +%Y%m%d%H%M`
    backup_dir=$backup_location
    welcome_msg="Welcome to use MySQL backup tools!"
    
    
    
    # 备份指定数据库中数据(此处我要备份的数据库为longxing)
    docker exec -i mymysql mysqldump -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -B longxing > $backup_dir/$backup_time.sql
    
    
     
    # 删除过期数据
    if [ "$expire_backup_delete" == "ON" -a  "$backup_location" != "" ];then
            `find $backup_location/ -type f -mtime +$expire_days | xargs rm -rf`
            echo "Expired backup data delete complete!"
    fi
    
    

    **注 在上面执行命令时一定不能为docker exec -it 不然执行任务时会出现:the input device is not a TTY错误 **
    执行以下命令:

    chmod u+x *.sh
    

    创建定时任务

    命令: crontab -e
    在编辑框输入:

    09 11 * * * cd /home/dbback;sh mysql_backup.sh >> log.txt 2>>log.txt
    
    

    这边做下注释:前面时间表示任务启动时间为11点09分。脚本位置为:/home/dbback目录下。后面就不用说了。

    最终执行结果:
    file

    cs