定时备份数据库脚本

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013705066/article/details/81943882

定时任务

crontab命令用于设置周期性被执行的指令。该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供之后读取和执行。
通常linux里都内置了crontab命令。如果没有请自行安装。

文件

crontab在/etc目录下面存在cron.hourly,cron.daily,cron.weekly,cron.monthly,cron.d五个目录和crontab,cron.deny二个文件。
cron.daily是每天执行一次的job
cron.weekly是每个星期执行一次的job
cron.monthly是每月执行一次的job
cron.hourly是每个小时执行一次的job
cron.d是系统自动定期需要做的任务
crontab是设定定时任务执行文件
cron.deny文件就是用于控制不让哪些用户使用Crontab的功能

每个用户都有自己的cron配置文件,通过crontab -e 就可以编辑,一般情况下我们编辑好用户的cron配置文件保存退出后,系统会自动就存放于/var/spool/cron/目录中,文件以用户名命名.linux的cron服务是每隔一分钟去读取一次/var/spool/cron,/etc/crontab,/etc/cron.d下面所有的内容.

一些命令

crontab –e : 修改 crontab 文件,如果文件不存在会自动创建。
crontab –l : 显示 crontab 文件。
crontab -r : 删除 crontab 文件。
crontab -ir : 删除 crontab 文件前提醒用户。

数据库定时备份脚本xtrabackup.sh

#!/bin/bash

 defaults_file="/etc/my.cnf" # mysql配置文件位置

 user="backup" #mysql账号

 password="backup" #mysql密码

 backup_dir="/path/to/backup/" #需要存档的根目录

 time_dir="$(date +"%Y%m%d%H%M%S")"

shell='innobackupex --defaults-file='$defaults_file' --user='$user' --password='$password'  --stream=tar /temp | ssh root@远端机子 "gzip -> '$backup_dir$time_dir'.tar.gz"'

 eval $shell

将脚本加入计划任务

          • command

minute hour day month week command

分 时 天 月 星期 命令


执行crontab –e
00 02 * * * /bin/bash /path/to/xtrabackup.sh

猜你喜欢

转载自blog.csdn.net/u013705066/article/details/81943882