Shell脚本之数据库备份

Shell脚本之数据库备份

注:最好还是做热备比较好,这种备份只适合短时间使用或临时使用

1.Shell脚本如下,具体查看注释

#!/bin/bash
#设置mysql备份目录
folder=/data/mysql/backups/
cd $folder
day=`date +%Y%m%d`
test -e ${folder}${day} || mkdir ${folder}${day}
cd $day
nowday=`date +%Y%m%d_%H%M%S`
mkdir $nowday
cd $nowday
#数据库服务器IP地址,一般为localhost
host=17.0.0.0
#用户名
user=root
#密码
password=123456
#备份db_mes的数据库
#db=数据库名称
mysqldump -h$host -u$user -p$password $db>$db.sql
#备份测试数据库
db=数据库名称
mysqldump -h$host -u$user -p$password $db>$db.sql
#备份数据库
db=数据库名称
mysqldump -h$host -u$user -p$password $db>$db.sql
db=数据库名称
mysqldump -h$host -u$user -p$password $db>$db.sql

#需要先安装expect插件,yum install expect\apt install expect
#下面这段命令表示的是,数据库备份完成后,要传到192.168.58.3的服务器指定位置中。
/usr/bin/expect << EOF
set timeout 600
spawn scp -r ${folder}${day} root@192.168.58.3:/home/mysql/MESdatabases/
expect {
	"*yes/no" { send "yes\r";exp_continue}
	"*password" { send "100trust\r"}
}
expect eof
EOF

#数据要保留的天数
days=7
day=`date -d "$days days ago" +%Y%m%d`
echo $day
rm -rf ${folder}${day}

2.设置定时执行脚本

vim /etc/crontab
注:目前在用,每天21:30使用root用户执行mysqlbf1.sh脚本
30 21 * * * root /data/mysql/mysqlbf1.sh

基本格式
*  *  *  *  *  command
分  时  日  月  周  命令
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令

crontab的一些例子

1.下面的例子表示每晚的21:30重启apache
30 21 * * * /usr/local/etc/rc.d/lighttpd restart

2.下面的例子表示每月1、10、22日的4 : 45重启apache。
45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart

3.下面的例子表示每周六、周日的1 : 10重启apache。
10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart

4.下面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启apache。
0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart

5.一月一号的4点重启apache
0 4 1 jan * /usr/local/etc/rc.d/lighttpd restart

6.每月的4号与每周一到周三的11点重启apache
0 11 4 * mon-wed /usr/local/etc/rc.d/lighttpd restart

7.晚上11点到早上7点之间,每隔一小时重启apache
* 23-7/1 * * * /usr/local/etc/rc.d/lighttpd restart

8.每一小时重启apache
* */1 * * * /usr/local/etc/rc.d/lighttpd restart

9.下面的例子表示每星期六的11 : 00 pm重启apache。
0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart

希望能帮助到大家!

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值