linux mysql crontab_Linux 使用crontab定时备份Mysql数据库

项目中数据库的数据是至关重要的!在实际项目中,遇到有客户机房断电导致数据库数据丢失的问题,又因为备份容灾不及时,导致部分数据恢复不了,而刚好这部分丢失的数据对于客户来说又是至关重要的,那么怎么办呢?盲羊补牢,为时晚矣!所以,对应日常数据库的自动备份千万不能马虎!首先想到的是,使用Linux的自动定时任务命令crontab对数据库进行定时备份!

1.在/home/test创建新脚本文件test_database_backup.sh:

[root@win7 /]# cd home/test

[root@win7 test]# touch test_database_backup.sh

[root@win7 test]# chmod 770 test_database_backup.sh

2.使用VI工具编写test_database_backup.sh备份数据库脚本内容:

# Name:test_database_backup.sh

# This is a ShellScript For Auto DB Backup and Delete old Backup

#备份地址

backupdir=/www/test_backup

#备份文件后缀时间

time=_` date +%Y_%m_%d_%H_%M_%S `

#需要备份的数据库名称

db_name=test

#mysql 用户名

#db_user=

#mysql 密码

#db_pass=

#mysqldump命令使用绝对路径

/home/server/mysql-5.6.21/bin/mysqldump $db_name | gzip > $backupdir/$db_name$time.sql.gz

#删除7天之前的备份文件

find $backupdir -name $db_name"*.sql.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1

3.在以上脚本中并没有填写db_user,db_pass,那么mysqldump怎么连接数据库呢?

[root@win7 /]cd /etc

[root@win7 etc]vi my.cnf

[mysqldump]

quick

max_allowed_packet = 16M

#在这里输入user及password,在执行mysqldump命令就不用输入用户名和密码了

user=root

password=123456

4.使用crontab创建定时任务

[root@win7 /]crontab -e

00 02 * * * /usr/bin/sh /home/test/test_database_backup.sh(这是你脚本存放的路径) >> /home/test/test_database_backup.log(这是log日志路径)

再用service crond restart重新启动定时任务服务即可!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值