linux shell 定时备份mysql数据库

安装 crontab


检测是否已安装 crontab

# crontab
-bash: crontab: command not found 

那说明没有安装 crontab 

开始安装:

# yum -y install vixie-cron

等待安装完成即可.

编写备份数据库shell

vim /usr/java/shell/bak_mysql.sh

脚本内容如下:

#!/bin/bash
# @Author:  hwj
# @Date:    2017-09-02
# @Desc:    backup dbName db data 

mysqlserver='127.0.0.1'
mysqldbname='dbName'   #数据库名
mysqluser='dbName'     #数据库用户名
mysqlpwd='dbPassword'  #数据库密码
mysqlbakdir='/usr/java/bak_msyql'   #数据库备份目录
if [ ! -d '$mysqlbakdir/`date +%Y`/`date +%m`' ];then
   mkdir -p $mysqlbakdir/`date +%Y`/`date +%m`
fi
sqlbakfile=$mysqlbakdir/`date +%Y`/`date +%m`/$mysqldbname`date +%F-%H-%M-%S`.sql

mysqldump -u$mysqluser -p$mysqlpwd   -h$mysqlserver --hex-blob $mysqldbname >$sqlbakfile
tar czvPf $sqlbakfile.tar.gz $sqlbakfile
rm $sqlbakfile

给 bak_mysql.sh 执行权限

# chmod u+x bak_mysql.sh

先执行一下看看脚本是否成功?

# ./bak_mysql.sh 

查看备份文件是否生成?
# cd /usr/java/bak_msyql
# ll

没有生成,那说明 bak_msyql.sql 脚本有问题,自行调试到正确为止.


添加计划任务


# crontab -e

这个时候操作跟 vim 一样.

输入:

0 4 * * * /usr/java/shell/bak_mysql.sh

保存.(上面这个是每天凌晨4点执行一次)

启动定时任务.
# /sbin/service crond start

查看crontab日志:
# tail -f /var/log/cron

把 crontab 设置为开机时自动运行
在/etc/rc.d/rc.local这个脚本的末尾加上 /sbin/service crond start 


其他说明

crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数

crontab -l //列出某个用户cron服务的详细内容

crontab -r //删除没个用户的cron服务

crontab -e //编辑某个用户的cron服务

/sbin/service crond start //启动服务 
/sbin/service crond stop //关闭服务 
/sbin/service crond restart //重启服务 
/sbin/service crond reload //重新载入配置 
/sbin/service crond status //查看状态

或者使用

# service crond start 
# service crond stop 
# service crond restart 
# service crond reload 
# service crond status

定时参数说明


crontab文件的含义:
 用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:
minute   hour   day   month   week   command     顺序:分 时 日 月 周
其中:
minute: 表示分钟,可以是从0到59之间的任何整数。
hour:表示小时,可以是从0到23之间的任何整数。
day:表示日期,可以是从1到31之间的任何整数。
month:表示月份,可以是从1到12之间的任何整数。
week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。
command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。
在以上各个字段中,还可以使用以下特殊字符:


星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。


参考博客

http://blog.csdn.net/testcs_dn/article/details/48829785
http://www.cnblogs.com/chen-lhx/p/5996781.html
http://blog.csdn.net/testcs_dn/article/details/48780971






猜你喜欢

转载自blog.csdn.net/huweijun_2012/article/details/77800832