加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

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

发布时间:2023-07-08 17:02:16 所属栏目:Linux 来源:
导读:这篇文章将为大家详细讲解有关“如何使用Centos的Crontab和shell脚本进行数据库备份”的知识,下文有详细的介绍,小编觉得挺实用的,对大家学习或工作或许有帮助,因此分享给大家做个参考,希望大家阅读完
这篇文章将为大家详细讲解有关“如何使用Centos的Crontab和shell脚本进行数据库备份”的知识,下文有详细的介绍,小编觉得挺实用的,对大家学习或工作或许有帮助,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
 
在Centos系统环境下使用Crontab定时备份全量备份Mysql数据库。
 
CentOS的Crontab任务调度配置文件路径在 /etc/crond.*
 
用户任务调度任务路径在/var/spool/cron
 
Crontab默认日志路径 /var/log/cron
 
1、Crond服务基本管理命令
 
service crond start //启动服务
 
service crond stop //关闭服务
 
service crond restart //重启服务
 
service crond reload //重新载入配置
 
查看crontab服务状态:service crond status
 
手动启动crontab服务:service crond start
 
2、Crond服务是默认随系统自动启动,如未启动则需要手动启动
 
chkconfig crond on
 
3、注意任务调度区分root用户与非root用户。
 
root用户任务调度编辑 /etc/contab 文件,例如:
 
vi /etc/crontab
 
#检测crontab是否在test.txt文件中写入数据
 
*/1 * * * * root echo 111 >> /home/vagrant/test.txt
 
非root用户 可以使用crontab命令
 
创建调度文件 crontab -e
 
查看调度文件 crontab -l
 
删除调度文件 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
 
备份脚本示例:
 
#!/bin/bash
 
#source /etc/profile
 
#设置mysql备份目录
 
folder=/home/mysqlbackup/
 
#数据库服务器,一般为localhost
 
host=10.2.48.90
 
mysqldump -h10.2.48.90 -uroot --all-databases | gzip > ${folder}`date +%Y%m%d%H%M%S`.gz
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!