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
#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
然后用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