Centos 定时压缩备份数据

简介:

今年公司买了一套OA产品,对于功能现在都还处在开发和配置阶段,作为管理员的我,需要对每天的数据及对应的数据库进行定期备份,因为OA产品是运行在Linux上的,所以我们需要Linux上配置shell脚本,然后通过计划任务来实现对数据的定时备份,对于相关脚本内容见下即可,但是需求是需要对指定的目录进行压缩然以日期进行命名,最终移动到指定的路劲即可。对于linux上的计划任务程序跟windows上的很相似,windows上我们可以直接运行taskschd.msc就可以打开,然后新建任务向导即可,但是在linux上比windows上的操作更简单,只需要连接对应的参数即可。linux上计划任务的命令为crontab ,通过后面的参数即可配置;我们可以通过man crontab查看相关帮助。

-e:编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件。
-l:显示某个用户的crontab文件内容,如果不指定用户,则表示显示当前用户的crontab文件内容。
-r:从/var/spool/cron目录中删除某个用户的crontab文件,如果不指定用户,则默认删除当前用户的crontab文件。
-i:在删除用户的crontab文件时给确认提示。

同样:crontal 的参数格式为  * * * * *    

一个 * 一小时当中的第几分钟 0-59

第二个 * 一天当中的第几个小时 0-23

第三个 * 一个月当中的第几天 1-31

第四个 * 一年当中的第几个月 1-12

第五个 * 一周当中的星期几 1-7

wKioL1eQeIiDab9qAABpOTSNdZY800.png-wh_50

配置介绍完了,我们就开始工作吧

我们通过ls –l查看当前的目录结构

我们已经写好脚本了,该脚本叫databackuper.sh,然后我们需要将/data目录下的Weaver目录数据压缩备份到waver_back目录中,然后以日期命名;

主要一定要在执行shell脚本的时候给脚本添加执行权限;chmod +x databackuper.sh   添加执行权限

我们在脚本中定义两个参数,$1 、$2,这样定义的话就比较灵活,当有多个文件需要备份的话,可以使用这样的方式,然后在执行shell的时候,我们需要在shell脚本后添加两个参数,一个是源,一个目标路劲;

1
. /databackuper .sh  /DATA/WEAVER  /DATA/WEAVER_BACKUP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#!/bin/bash   
SOURCE=$1    
TARGET=$2    
CPEXEC=$( which  cp )    
MKDIREXEC=$( which  mkdir )    
CURDATE=$( date  +%Y-%m-%d)    
BAKDIRTMP=${SOURCE%*/}    
BAKDIRNAME=${BAKDIRTMP ##*/}$CURDATE    
BASEDIR=${BAKDIRTMP%/*}
 
if  [ ! -d  "$SOURCE"  ];  then       
     echo  "$(date +%Y-%m-%d_%H:%M:%S) - The source $SOURCE is not existed you specified"  >> /var/log/ ${BAKDIRTMP ##*/}.log        
     exit  2    
     fi
     
if  [ ! -d  "$TARGET"  ];  then       
     echo  "$( date  +%Y-%m-%d_%H:%M:%S) - The target $TARGET is not existed you spec    
     ified" >> /var/log/ ${BAKDIRTMP ##*/}.log        
     exit  22    
     fi
# $MKDIREXEC -p $TARGET/$BAKDIR   
# $CPEXEC -rf $SOURCE/* $TARGET/$BAKDIR/
 
cd  $TARGET &&  tar  zcf ${BAKDIRNAME}. tar .gz -C $BASEDIR ${BAKDIRTMP ##*/}
 
if  "$?"  - ne  0 ];  then
       echo  "$(date +%Y-%m-%d_%H:%M:%S) - Backup directory: $SOURCE to $TARGET/${BAKDIRNAME}.tar.gz is failed"  >> /var/log/ ${BAKDIRTMP ##*/}.log    
       else       
       echo  "$(date +%Y-%m-%d_%H:%M:%S) - Backup directory: $SOURCE to $TARGET/${BAKDIRNAME}.tar.gz is successful"  >> /var/log/ ${BAKDIRTMP ##*/}.log    
fi    
exit  0

上面的方式就是比较有扩展性,然后我们也可以直接修改变量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#!/bin/bash  
#指定源和目标 
SOURCE= /DATA/WEAVER    
TARGET= /DATA/WEAVER_BACKUP
CPEXEC=$( which  cp )   
MKDIREXEC=$( which  mkdir )    
CURDATE=$( date  +%Y-%m-%d)    
BAKDIRTMP=${SOURCE%*/}    
BAKDIRNAME=${BAKDIRTMP ##*/}$CURDATE    
BASEDIR=${BAKDIRTMP%/*}
if  [ ! -d  "$SOURCE"  ];  then       
echo  "$(date +%Y-%m-%d_%H:%M:%S) - The source $SOURCE is not existed you specified"  >> /var/log/ ${BAKDIRTMP ##*/}.log        
exit  2    
     fi
if  [ ! -d  "$TARGET"  ];  then       
echo  "$(date +%Y-%m-%d_%H:%M:%S) - The target $TARGET is not existed you spec    ified"  >> /var/log/ ${BAKDIRTMP ##*/}.log        
exit  22    
fi
# $MKDIREXEC -p $TARGET/$BAKDIR   
# $CPEXEC -rf $SOURCE/* $TARGET/$BAKDIR/
cd  $TARGET &&  tar  zcf ${BAKDIRNAME}. tar .gz -C $BASEDIR ${BAKDIRTMP ##*/}
if  "$?"  - ne  0 ];  then      
echo  "$(date +%Y-%m-%d_%H:%M:%S) - Backup directory: $SOURCE to $TARGET/${BAKDIRNAME}.tar.gz is failed"  >> /var/log/ ${BAKDIRTMP ##*/}.log    
     else       
echo  "$(date +%Y-%m-%d_%H:%M:%S) - Backup directory: $SOURCE to $TARGET/${BAKDIRNAME}.tar.gz is successful"  >> /var/log/ ${BAKDIRTMP ##*/}.log    
fi    
exit  0

这样的话,我们直接执行即可,就不用添加任何参数了

1
. /databackuper .sh  执行即可;

然后我们定义计划任务进行备份,我们准备每天晚上23:30进行备份一次

1
2
crontal –e
30 23 * * *   /root/DATA/databackuper-new .sh

每天晚上23:30  执行一次  /root/data/databackuper-new.sh  脚本一次

image



本文转自 高文龙 51CTO博客,原文链接:http://blog.51cto.com/gaowenlong/1828368,如需转载请自行联系原作者

相关文章
|
Linux 测试技术 Docker
Linux系统:第十三章:centos误删文件如何恢复文件数据
Linux系统:第十三章:centos误删文件如何恢复文件数据
439 0
Linux系统:第十三章:centos误删文件如何恢复文件数据
|
2月前
|
应用服务中间件 Linux nginx
让 CentOS 定时重启 Nginx
在CentOS上设置Nginx定时重启可通过`cron`或`systemctl`
138 0
|
4月前
|
SQL 关系型数据库 MySQL
这篇文章带你了解:如何一次性将Centos中Mysql的数据快速导出!!!
这篇文章带你了解:如何一次性将Centos中Mysql的数据快速导出!!!
|
4月前
|
NoSQL Linux 网络安全
【专栏】在 RHEL 8 或者 CentOS 8 上顺利安装并运行MongoDB,以处理非结构化数据和扩展技术栈
【4月更文挑战第28天】本文档介绍了如何在RHEL或CentOS 8上安装MongoDB,包括环境准备(系统更新、依赖安装、硬件需求和sudo用户)、导入MongoDB GPG公钥、创建Yum仓库、安装MongoDB社区版,以及后续的基本配置和验证(启动服务、防火墙设置和连接验证)。通过这些步骤,用户可以顺利安装并运行MongoDB,以处理非结构化数据和扩展技术栈。
173 1
|
4月前
|
监控 Linux 网络安全
linux centos7 rsync+sersync实现数据实时同步
linux centos7 rsync+sersync实现数据实时同步
133 0
|
4月前
|
SQL 关系型数据库 MySQL
centos实现mysql定时备份(单机)
centos实现mysql定时备份(单机)
203 0
|
10月前
|
关系型数据库 MySQL Linux
centos7利用crontab进行mysql定时备份
centos7利用crontab进行mysql定时备份
195 0
|
SQL 关系型数据库 MySQL
Centos7下利用crontab+bypy实现自动备份数据到百度网盘
Centos7下利用crontab+bypy实现自动备份数据到百度网盘
212 0
|
云安全 关系型数据库 MySQL
Centos文件压缩与打包43.240.72
Centos文件压缩与打包43.240.72
|
测试技术 Linux 数据库
性能测试 CentOS下结合InfluxDB及Grafana图表实时展示JMeter相关性能数据2
性能测试 CentOS下结合InfluxDB及Grafana图表实时展示JMeter相关性能数据2
107 0