mysqldump备份

说明:

 

    系统:阿里云的centos 7

    mysql:mysql-5.6.27

    脚本来源:冰狼爱魔

    相关链接:mysql备份的三种详解 mysql备份与恢复

 

一、备份

    首先创建备份的目标文件夹 

    备份时使用mysqldump进行备份

mysqldump -h localhost -u用户名 -p 数据库 > db_20170915.sql  ##db_20170915.sql.gz为压缩备份

    如果为远程备份则需要把localhost改为相应的IP地址即可

    当我想把B服务器上的备份到A服务器上时我这里出现了一个错误,好像是版本的问题,错误如下:

mysqldump: Couldn't execute 'SET OPTION SQL_QUOTE_SHOW_CREATE=1': You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'OPTION SQL_QUOTE_SHOW_CREATE=1' at line 1 (1064

二、备份恢复

mysqldump -h localhost -u用户名 -p 数据库 < db_20170915.sql

这就算是完成了一次数据库的备份与恢复,需要注意:这是把所有的表都备份到一起

三、添加定时任务进行自动备份

创建sh脚本并赋权限:
创建:touch mysql_back.sh  
赋权限:chmod 755 mysql_back.sh  
脚本内容如下:
# Name:mysql_backup.sh
# 数据库备份和删除7天之前的数据
#备份地址
backupdir=/home/mysql
#备份文件后缀时间
time=_` date +%Y_%m_%d_%H_%M_%S `
#需要备份的数据库名称
db_name=zbx_db
#mysql 用户名
#db_user=
#mysql 密码
#db_pass=
#mysqldump命令使用绝对路径
/usr/local/mysql/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
回到系统根目录 cd ~  cd..
添加定时任务:crontab -e
输入一下并保存:
00 00 * * * /usr/bin/sh /home/timeShell/mysql_backup.sh >> /home/timeShell/mysql_backup.log
使定时器生效:service crond restart

免密设置

打开my.cnf
cd /etc
vi my.cnf
[mysqldump]
quick
max_allowed_packet = 16M
#在这里输入user及password,在执行mysqldump命令就不用输入用户名和密码了
user=root
password=123456

四、设置mysql自启动

将服务文件拷贝到init.d下,并重命名为mysql:
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
赋予可执行权限:chmod +x /etc/init.d/mysqld
添加服务:chkconfig --add mysqld
显示服务列表:chkconfig –list

3,4,5都是on配置成功,如果不是:chkconfig --level 345 mysql on
重启:reboot
验证:netstat -na | grep 3306
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值