CentOS系统mysql数据库自动备份脚本

#!/bin/bash

databases=(要备份的数据库名)

basepath='/root/backup/'

if [ ! -d "$basepath" ]; then
	mkdir -p "$basepath"
fi

for db in ${databases[*]}
	do
		/bin/nice -n 19 /usr/bin/mysqldump -u数据库账号 -p数据库密码 --database $db > $basepath$db-$(date +%Y%m%d).sql

		/bin/nice -n 19 tar zPcf $basepath$db-$(date +%Y%m%d).sql.tar.gz $basepath$db-$(date +%Y%m%d).sql

		find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} \; 
	done


	#rm -rf $basepath/*.sql

脚本如上,我这里的脚本为/root/db.sh

备份的地址

basepath='/root/backup/'
可以自己修改


/bin/nice -n 19是设置优先级


备份数据库的命令是mysqldump,命令在/usr/bin/目录下面


这句代码是删除7天前的备份文件

find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} \; 


这句代码是删除生成的sql中间文件,但是我这里把它注释掉了,也就是说不会删除,如果要删除自己把注释去掉

#rm -rf $basepath/*.sql


注意代码最好是在CentOS系统中手动敲,别在windows系统中敲了再传到CentOS系统中,因为有可能因为编码原因造成脚本运行有问题。


脚本写好后要通过crontab -e命令设置脚本定时运行

crontab -e

0 3 * * * /root/db.sh

然后保存

这样就是每天凌晨3:00自动运行脚本,即自动备份数据库

关于crontab命令是详细用法大家可以参考如下:

http://blog.csdn.net/qq229596421/article/details/51791742


续:

不好意思这里又写个续作为碰到问题后解决的过程


实际上上面那个脚本是有点问题的,当我们去手动执行那个脚本的时候是会报警告的:

Using a password on the command line interface can be insecure

什么意思呢,意思就是我们把账号密码写在shell脚本里面是不安全的。当然这个是个安全警告,不影响备份。可是如果你是个像作者一样矫情的码农非得一点问题都不能出怎么办呢,当然这个问题是可以解决的。


那就是把账号密码写在数据库配置文件中。该文件一般在/etc/my.cnf或者/etc/my.conf,如果你找不到也可以用

find / -name my.cnf

命令去搜索。


找到后在最后面插入

[mysqldump]

host=localhost

user=你的账号

password=你的密码


输入完后保存。

完了之后我们先手动运行一下mysql数据库的备份命令

/usr/bin/mysqldump --defaults-extra-file=/etc/my.cnf 要备份的数据库名 > bak.sql


完了可以看到没有报错,然后数据库备份文件也出来了,所以上面的备份脚本要稍作修改

#!/bin/bash

databases=(要备份的数据库名)

basepath='/root/backup/'

if [ ! -d "$basepath" ]; then
	mkdir -p "$basepath"
fi

for db in ${databases[*]}
	do
		/bin/nice -n 19 /usr/bin/mysqldump --defaults-extra-file=/etc/my.cnf --database $db > $basepath$db-$(date +%Y%m%d).sql

		/bin/nice -n 19 tar zPcf $basepath$db-$(date +%Y%m%d).sql.tar.gz $basepath$db-$(date +%Y%m%d).sql

		find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} \; 
	done


	#rm -rf $basepath/*.sql




数据库自动备份参考链接:

http://my.oschina.net/u/1440383/blog/313803

http://blog.chinaunix.net/uid-27155075-id-3301913.html

http://blog.csdn.net/noise111/article/details/8625061

http://88250.b3log.org/backup-mysql-shell


解决Using a password on the command line interface can be insecure问题参考链接:

http://www.laozuo.org/6799.html

http://www.111cn.net/database/mysql/59006.htm






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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值