linux里面定时备份mysql数据库

一、cron方式

1、创建命令文件夹

mkdir -p /data/mysql/scripts

创建存放数据的文件夹

mkdir -p /data/mysql/data

创建存放日志的文件夹

mkdir -p /data/mysql/logs

2、在/data/mysql/scripts目录下面创建beifen.sh命令文件,为以下内容:

#!/bin/bash
#备份根目录
BEIFEN_ROOT=/data/mysql
#当前日期
DATE=$(date +%Y%m%d)
#查询所有数据库
#-uroot -p123456表示使用root账号执行命令,且root账号的密码为:123456
#DATABASES=$(mysql -uroot -p123456 -e "show databases" | #grep -Ev "Database|sys|information_schema|performance_schema|mysql")
DATABASES=$(mysql --defaults-extra-file=/etc/my.cnf -e "show databases" | grep -Ev "Database|sys|information_schema|performance_schema|mysql")
#循环数据库进行备份
for db in $DATABASES
do
echo
echo ----------$BEIFEN_ROOT/data/${db}_$DATE.sql.gz BEGIN----------
mysqldump --defaults-extra-file=/etc/my.cnf --default-character-set=utf8 -q --lock-all-tables --flush-logs -E -R --triggers -B ${db} | gzip > $BEIFEN_ROOT/data/${db}_$DATE.sql.gz
echo ----------$BEIFEN_ROOT/data/${db}_$DATE.sql.gz COMPLETE----------
echo
done
echo "done"

当然我们要给/data/mysql/scripts/beifen.sh赋予权限

chmod 777 /data/mysql/scripts/beifen.sh

原本我是想这么写:

DATABASES=$(mysql -uroot -p123456 -e "show databases" | #grep -Ev "Database|sys|information_schema|performance_schema|mysql")`

但是如果直接这么写,把密码写在命令里面,linux会报错,告诉你不安全,所以我把用户名密码都写在了/etc/my.cnf里面,然后用--defaults-extra-file=/etc/my.cnf来代替用户名密码

3、修改/etc/my.cnf

vi /etc/my.cnf

如果没有[client]就在最后添加内容,如果有了就修改一下

[client]
port=3306
socket=/tmp/mysql.sock
default-character-set = utf8mb4
host=localhost
user=root
password =自己的密码

4、执行crontab -e命令,把里面的内容更改为

0 2 * * * /data/mysql/scripts/beifen.sh > /data/mysql/logs/beifen.log 2>&1

这里表示每天的2点0分执行/data/mysql/scripts/beifen.sh文件,并且把日志输出在/data/mysql/logs/beifen.log里面。

可以用命令crontab -l查看定时任务有没有改成功。

然后在设定的时间去看看/data/mysql/data里面有没有备份文件

二、cron定时删除之前的sql备份文件

1、创建/data/mysql/scripts/qingli.sh

#!/bin/sh
find /data/mysql/data/ -mtime +1 -name "*.sql.gz" -exec rm -rf {} \;

-mtime+1表示修改时间一天之前的,-mtime-1表示1天之内

给/data/mysql/scripts/qingli.sh添加权限

chmod 777 /data/mysql/scripts/qingli.sh

2、定时执行
执行命令crontab -e添加

0 1 * * * /data/mysql/scripts/qingli.sh > /data/mysql/logs/qingli.log 2>&1

查看定时任务 crontab -l
在这里插入图片描述
我的博客地址:https://www.dbhx.vip/article/85

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值