如何使用Centos的Crontab和shell脚本进行数据库备份

Admin 2023-05-05 群英技术资讯 353 次浏览

这篇文章将为大家详细讲解有关“如何使用Centos的Crontab和shell脚本进行数据库备份”的知识,下文有详细的介绍,小编觉得挺实用的,对大家学习或工作或许有帮助,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

在Centos系统环境下使用Crontab定时备份全量备份Mysql数据库。

CentOS的Crontab任务调度配置文件路径在 /etc/crond.*

用户任务调度任务路径在/var/spool/cron

Crontab默认日志路径 /var/log/cron

1、Crond服务基本管理命令

  1. service crond start //启动服务
  2. service crond stop //关闭服务
  3. service crond restart //重启服务
  4. service crond reload //重新载入配置
  5. 查看crontab服务状态:service crond status
  6. 手动启动crontab服务:service crond start

2、Crond服务是默认随系统自动启动,如未启动则需要手动启动

  1. chkconfig crond on

3、注意任务调度区分root用户与非root用户。

root用户任务调度编辑 /etc/contab 文件,例如:

  1. vi /etc/crontab
  2. #检测crontab是否在test.txt文件中写入数据
  3. */1 * * * * root echo 111 >> /home/vagrant/test.txt

非root用户 可以使用crontab命令

  1. 创建调度文件 crontab -e
  2. 查看调度文件 crontab -l
  3. 删除调度文件 crontab -r

 

如果无法定时执行任务,可查看日志 /var/log/cron出现 ERROR (getpwnam() failed) 的错误,原来是没有在命令中加入root导致的

分 小时 日 月 星期 命令

0-59 0-23 1-31 1-12 0-6 command

例如:

*/1 * * * * root /sbin/echo `date` >> /home/test.txt

(取值范围,0表示周日一般一行对应一个任务)

记住几个特殊符号的含义: “*”代表取值范围内的数字, “/”代表”每”, “-”代表从某个数字到某个数字, “,”分开几个离散的数字

4、注意

配置完成任务调度后,需要立刻执行的话,重启服务或重新载入配置。不然需要等2分钟后才会自动开始执行。

还需要注意就是环境变量的问题:

1)脚本中涉及文件路径时写全局路径;

2)脚本执行要用到java或其他环境变量时,通过source命令引入环境变量,如:

cat start_cbp.sh

#!/bin/sh

source /etc/profile

export RUN_CONF=/usr/sbin/mysqldump

备份脚本示例:

  1. #!/bin/bash
  2. #source /etc/profile
  3. #设置mysql备份目录
  4. folder=/home/mysqlbackup/
  5. #数据库服务器,一般为localhost
  6. host=10.2.48.90
  7. mysqldump -h10.2.48.90 -uroot --all-databases | gzip > ${folder}`date +%Y%m%d%H%M%S`.gz

“如何使用Centos的Crontab和shell脚本进行数据库备份”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业技术相关的知识可以关注群英网络网站,小编每天都会为大家更新不同的知识。 群英智防CDN,智能加速解决方案

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

猜你喜欢

成为群英会员,开启智能安全云计算之旅

立即注册
专业资深工程师驻守
7X24小时快速响应
一站式无忧技术支持
免费备案服务
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
在线客服
微信公众号
返回顶部
返回顶部 返回顶部
在线客服
在线客服