服务器以当日的日期备份文件,Linux平台下自动备份文件到远程FTP服务器并删除指定日期前的备份linux服务器应用 -电脑资料...

2023-05-16

这里要把/backup/oracledata/ts目录下面的所有文件备份到/backup/oracledata/tsbak里面,并且保存为TianShan20140409.tar.gz的压缩文件(20140409是指备份执行时当天的日期),然后只保留最近7天的备份,再把备份文件通过ftp服务器上传到指定空间/oraclebackup下,只保留最近7天的数据,

场景说明

操作系统:Centos

FTP: 192.168.148.121 用户:dell 密码:123

解决方案:利用Linux crontab-自动化的任务 实现自动备份

实现步骤

1、创建保存备份文件的目录

[root@localhost ts]# mkdir -p /backup/oracledata/tsbak

2、创建备份脚本文件 tianshanftp.sh    vim /backup/oracledata/tsbak/tianshanftp.sh ;输入以下内容

(详细的代码解释)   #!/bin/sh

FTP_IP=192.168.148.121      #ftp地址

FTP_USER=dell           #ftp用户名

FTP_PASS=123           #ftp密码

FTP_backup=/oraclebackup         #ftp上存放备份文件的目录,需要先在FTP上面建好

BK_DR=/backup/oracledata/tsbak    #备份文件存放路径

DB_DR=/backup/oracledata/ts  #已经存在文件

DAYS=7                    #DAYS=7代表删除7天前的备份,即只保留最近7天的备份

LINUX_USER=root           #系统用户名

date=` date +%Y%m%d `

tar zcvf $BK_DR/TianShan$date.tar.gz $DB_DR

chown -R $LINUX_USER:$LINUX_USER $BK_DR  #更改备份数据库文件的所有者

find $BK_DR -name "TianShan*" -type f -mtime +$DAYS -exec rm {} \;  #删除7天前的备份文件(注意:{} \;中间有空格)

deldate=` date -d -7day +%Y%m%d `   #删除ftp服务器空间7天前的备份

ftp -i -v -n $FTP_IP <

【#它使用I/O重定向的形式来将一个命令序列传递到一个交互程序或者命令中,比如ftp、cat,或者ex文本编辑器.   本句可以理解从

binary         #设置二进制传输

cd $FTP_backup  #进入ftp目录

lcd $BK_DR  #列出本地目录

mput TianShan$date.tar.gz TianShan$date.tar.gz    #上传目录中的文件

mdelete TianShan$deldate.tar.gz TianShan$deldate.tar.gz  #删除ftp空间7天前的备份

bye

END

如果手动执行 sh没有问题的话,而放到crontab 执行报错话,请把上面的注释删掉,在执行试试,Linux平台下自动备份文件到远程FTP服务器并删除指定日期前的备份linux服务器应用》(https://www.unjs.com)。可以直接用下面【【】】里面的代码即可。

【【   #!/bin/sh

FTP_IP=192.168.148.121

FTP_USER=dell

FTP_PASS=123

FTP_backup=/oraclebackup

BK_DR=/backup/oracledata/tsbak

DB_DR=/backup/oracledata/ts

DAYS=7

LINUX_USER=root

date=` date +%Y%m%d `

tar zcvf $BK_DR/TianShan$date.tar.gz $DB_DR

chown -R $LINUX_USER:$LINUX_USER $BK_DR

find $BK_DR -name "TianShan*" -type f -mtime +$DAYS -exec rm {} \;

deldate=` date -d -7day +%Y%m%d `

ftp -i  -v -n $FTP_IP <

user $FTP_USER $FTP_PASS

binary

cd $FTP_backup

lcd $BK_DR

mput TianShan$date.tar.gz

mdelete TianShan$deldate.tar.gz

bye

END  】】

3、修改文件属性,使其可执行

chmod +x /backup/oracledata/tsbak/tianshanftp.sh

4、修改/etc/crontab   vi /etc/crontab     在下面添加

5 2 * * * root /backup/oracledata/tsbak/tianshanftp.sh   >> /backup/oracledata/tsbak/mylog.log 2>&1  #表示每天凌晨2点5分执行备份,并保持对应日志

5、重新启动crond使设置生效

service crond restart #启动

每天你在/backup/oracledata/tsbak目录下面可以看到类似TianShan20140409.tar.gz这样的压缩文件,同时在FTP服务器下的 oraclebackup目录下也有一个TianShan20140409.tar.gz这样的压缩文件,

如果需要恢复文件的时候,只需要把这个文件解压即可

解压缩:tar -zxvf TianShan20140409.tar.gz​

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

服务器以当日的日期备份文件,Linux平台下自动备份文件到远程FTP服务器并删除指定日期前的备份linux服务器应用 -电脑资料... 的相关文章

随机推荐