数据库备份常有,实现备份,大概需要3个步骤:
目录
1.创建数据库备份用户
2.创建数据库备份shell脚本
3.创建定时任务
1.创建数据库备份用户
为了数据安全,不建议使用root用户。举例:创建数据库备份用户 dump,并将数据库dbname授权给它。
create user dump@'%' identified by '123456';
grant SELECT,INDEX,LOCK TABLES,CREATE VIEW,SHOW VIEW,EVENT,TRIGGER on dbname.* to dump@'%' with grant option;
grant PROCESS,RELOAD on *.* to dump@'%' with grant option;
flush privileges;
2.创建数据库备份shell脚本
如创建db_bak.sh
mkdir -p /root/data/db_bak.sh
#!/bin/bash
DATA_PATH=/data/mysql/DBbakup
BAK_DATE=$(date "+%Y%m%d")
RM_DATE=$(date -d '-90 days' "+%Y%m%d")
MYSQL_HOME=/usr/local/mysql
DB=DBname
IP=127.0.0.1
PORT=3306
USER=dump
PWD=123456
#目录不存在,则创建
[ ! -d "$DATA_PATH" ] && mkdir -p "$DATA_PATH"
echo "bakup mysql data ${DB}: "${DATA_PATH}/${DB}_${BAK_DATE}.sql.gz
${MYSQL_HOME}/mysqldump -h ${IP} -P ${PORT} -u ${USER} --password=${PWD} -R -E \
--databases ${DB} | gzip > ${DATA_PATH}/${DB}_${BAK_DATE}.sql.gz
echo "delete old dateAt ${RM_DATE} data: "${DATA_PATH}/${RM_DATE}.sql.gz
rm -f ${DATA_PATH}/${RM_DATE}.sql.gz
3.创建定时任务
打开定时任务列表
crontab -e
在任务列表中追加一下cron表达式,后面跟只要执行的shell脚本。
如:每天凌晨2:30执行
30 2 * * * /root/data/db_bak.sh
关于Linux上的Cron表达式,很多博文都是云云。标准只有5位,从左到右分别表示:分钟、小时、日、月、周
贴一张官方图解:
更多详情见:Automate your Linux system tasks with cron | Enable Sysadmin