linux定时备份数据库(mysql)

[root@win7 /]# cd home/test
[root@win7 test]# touch test_database_backup.sh
[root@win7 test]# chmod 770 test_database_backup.sh

先新建test文件,然后建一个shell脚本,在给shell脚本权限


给shell脚本写上

# Name:test_database_backup.sh
# This is a ShellScript For Auto DB Backup and Delete old Backup
#备份地址
backupdir=/home/test_backup        //这里你要自己新建一个目录
#备份文件后缀时间
time=_` date +%Y_%m_%d_%H_%M_%S `
#需要备份的数据库名称
db_name=test               //写你要对应的数据库
#mysql 用户名
#db_user=
#mysql 密码
#db_pass=
#mysqldump命令使用绝对路径

/usr/bin/mysqldump  这个你要自己  find / -name  'mysqldump'   确定一下位置

/usr/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


写了上面这些代码 你链接 肯定是链接不上的 你需要 配合 mysqldump

[root@win7 /]cd /etc
[root@win7 etc]vi my.cnf

然后看看你有没有下面的代码   那些没有补那些,全部没有就粘贴

[mysqldump]
quick
max_allowed_packet = 16M
#在这里输入user及password,在执行mysqldump命令就不用输入用户名和密码了
user=root
password=123456

都配置完了   你就先  跑一下 回到  你写shell脚本的地方  ./test_database_backup.sh  看看有没有报错  

没有的话就开始创建定时任务

[root@win7 /]crontab -e

就会像vim一样


*/1 * * * * /usr/bin/sh /home/test/database_backup.sh >> /home/backup_log/database_backup.log    写上这句话   一秒执行一次

                /home/test/database_backup.sh  目录位置一定要对

               /home/backup_log/database_backup.log  这个自己对位置新建一个

:wq保存退出

service crond restart  重启crontab

这么知道定时任务在运行

tail -f /var/log/cron
执行这个命令(或者去你保存sql文件的目录看看有没有文件产生)





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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

An_s

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

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

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

打赏作者

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

抵扣说明:

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

余额充值