mysql备份有很多种,我们最先听别人说的是二进制日志备份呢数据库,但是我们一般不适用二进制日志备份数据。
最长使用的是mysqldump备份数据库。(现在刚学的是定时使用shell脚本备份数据库)
mysqldump备份数据库的命令:
mysqldump -u用户名 -p 数据库名(test) > 存放位置( ./test.sql )
或者: mysqldump -h ip地址 -u用户名 -p密码 数据库名 (test) > 存放位置 (./test.sql)
(手动)还原:
删除test的数据库
mysql > drop database test;
删除之后导入备份文件没有test数据库
注意:mysqldump备份出来的数据库是插入语句,还原的时候没有办法创建数据库需要手动创建数据库
手动创建test的数据库
mysql > create database test;
还原test数据库
mysql -uroot -p 数据库名< test.sql
前面备份数据只是一个测试,最好的方法是让程序帮我们去做一些事情。我们就用shell去定时执行任务。
shell和shell脚本区别:
shell是指一种应用程序,该应用程序提供是一个图形界面,用户通过这个界面访问操作系统内核的服务。
shell脚本(shell script),是一种为shell编写的脚本程序,(我们通常说的shell指的是shell脚本)。
在/root/mysqlbackup/mysqlbackup.sh下写了一个简单的shell脚本:
#!/bin/bash
#file:/root/mysqlbackup
backupdir=/root/mysqlbackup/
cd "$backupdir"
time=`date '+%Y%m%d %H:%M:%S'`
mysqldump -uroot -p123456 test(数据库1,数据库2) | gzip> ./test-"$time".sql.gz
修改文件属性,使其执行(主要是检测shell脚本能不能正常运行)
chmod +x ./mysqlbackup.sh
./mysqlbackup
然后用crontab命令执行
crontab -e; 执行命令行
crontab cron restart / service cron restart 重启cron服务;
service cron status; 查看crontab状态
分 时 日 月 周
* * * * *
定时任务日志位置 : /var/log/cron.log
例如 : */1 * * * * curl servername/home/test/test > /dev/null 2>&1
每分钟向数据库中写入一条数据,定时任务每分钟执行url就行。
常见crontab错误类型:
如果在日志文件中执行一条语句出现 : No MTA installed,discarding output
则crontab执行脚本时,不会直接输出错误的信息,而是会以邮件的形式发送到邮箱中,如果没有安装邮件服务器,就会报错误。
这时候可以在每条定时脚本后面加入 : > /dev/null 2>&1