linux mysql使用mysqldump备份定时执行shell脚本

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



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值