Linux 用 crontab 对mysql进行自动备份,无需输入密码

本文介绍如何在Linux环境下,通过编写shell脚本并结合crontab定时任务,实现对mysql数据库的每日凌晨2点自动备份。文章详细解释了脚本编写过程,包括解决密码输入问题的方法,以及定时任务的具体设置。

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

实现需求:每天凌晨2点对Linux服务器上的mysql数据库进行自动备份。

实现步骤:1,编写数据库备份脚本     2,编写crontab定时任务

1,编写数据库备份脚本

mysql数据库导出脚本,脚本名称可以定义为 “db-backup.sh”,内容如下:

/usr/bin/mysqldump -u root -p flightboot | gzip > /usr/local/backup/flightboot-bak.sql.gz

可以手动执行一下脚本,可以正常备份。但是如果将该脚本添加到定时任务中,是有问题的,因为该脚本手动执行的时候,需要输入密码,而定时任务是不可能手动输入密码的。解决该问题,只需要将数据库用户名和密码放到一个配置文件中,并修改脚本即可。

配置文件名称 “.my.cnf” ,将该文件放到根目录(root)下,文件内容:

[mysqldump]
user="root" 
password ="123456" 

修改文件权限,只允许当前用户使用:

chmod 600 .my.cnf

修改脚本,只需要将脚本中的 “-p” 去掉即可,修改后如下:

/usr/bin/mysqldump -u root flightboot | gzip > /usr/local/backup/flightboot-bak.sql.gz

2,编辑定时任务

编辑定时任务命令:

crontab -e

定时任务内容:

0 2 * * * /usr/local/backup/db-backup.sh

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值