Linux下MySQL定时备份

本文介绍了一种通过编写shell脚本来实现MySQL数据库定时备份的方法,并提供了详细的步骤指导,包括脚本编写、权限设置、crontab配置及常见问题解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



MySQL定时备份

2016926

14:18

最重要的要点

注意事项

1.测试脚本是否正常执行

2.备份文件放在可用容量大的磁盘(df) 

3.mysqldump不要使用软链接,直接使用全路径

1.编写备份脚本backup.sh

脚本1

#!/bin/bash

/usr/local/mysql/bin/mysqldump -uroot -p123mhub  >

/home/zs/software/mysqlbackup/mhub_$(date+%Y%m%d).sql

脚本2

#!/bin/bash

/usr/local/mysql/bin/mysqldump -uroot -p123mhub  | gzip >

/home/zs/software/mysqlbackup/mhub_$(date+%Y%m%d).sql.gz

2.加权限

chmod 777 backup.sh

#给脚本添加权限

3.测试脚本能否备份

能备份再往下一步

4.编辑crontab

crontab -e

#编辑定期调度

*/1 * * * * /home/zs/software/mysqlbackup/backup.sh

#每分钟调用一次脚本

crontab -l

#查看是否编辑成功

5.观察日志看能够执行并生成备份sql

tail -f /var/log/cron

#查看脚本执行情况

6.还原数据库

脚本1

source sql文件存放路径

#还原数据库

脚本2

gzip -d sql文件.gz

source sql文件存放路径

 

#解压成sql

#还原数据库

 

问题

1:直接使用执行脚本可以备份,使用crontab备份只有0KB,没有数据

原因:使用mysqldump命令时没有指定全路径

解决:使用mysqldump的全路径,而不要使用软链接

参考

http://blog.csdn.net/testcs_dn/article/details/48829785

http://www.2cto.com/database/201502/376262.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

甘蓝聊Java

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

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

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

打赏作者

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

抵扣说明:

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

余额充值