Linux环境定时备份MySQL数据库

数据库备份常有,实现备份,大概需要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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流沙QS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值