一、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