欢迎来到个人简历网!永久域名:gerenjianli.cn (个人简历全拼+cn)
当前位置:首页 > 范文大全 > 实用文>Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份

Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份

2022-12-22 08:10:31 收藏本文 下载本文

“吃八个蛋挞”通过精心收集,向本站投稿了2篇Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份,下面是小编为大家整理后的Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份,欢迎大家借鉴与参考,希望对大家有所帮助。

Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份

篇1:Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份

这里要把/backup/oracledata/ts目录下面的所有文件备份到/backup/oracledata/tsbak里面,并且保存为TianShan0409.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 《 END #打开ftp服务器。21为ftp端口  《END 和最后的 END:术语叫:当前文档here documents. here document 就是一段特殊目的的代码块

【#它使用I/O重定向的形式来将一个命令序列传递到一个交互程序或者命令中,比如ftp、cat,或者ex文本编辑器。  本句可以理解从《END开始以非对话模式的ftp连接,直到输入END为止的所有命令。  当然END这个名字是可以随便取的,不一定必须是END,可以取其它的名字,

user $FTP_USER $FTP_PASS  #用户名、密码

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 执行报错话,请把上面的注释删掉,在执行试试。可以直接用下面【】里面的代码即可。

【【  #!/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 《 END

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?

篇2:linux下数据库自动备份并上传到远程服务器linux网页制作

在大量工作量的情况下我们总希望能让系统自动完成一些功能,像数据库备份如果人工天天做也麻烦,今天我们提供一个在linux自动备份数据库并上传到远程服务器的有效方法,

代码如下复制代码

#!/bin/bash

#FTP信息

FTP_IP=

FTP_USER=

FTP_PASS=

#备份数据库

/etc/init.d/mysqld stop

MySQLBakName=MySQL_$(date +”%Y%m%d”).tar.gz

tar zcf /home/backup/$MySQLBakName /var/lib/mysql

/etc/init.d/mysqld start

#备份网站

WebBakName=Web_$(date +%Y%m%d).tar

tar cf /home/backup/$WebBakName /home/www

#操作FTP

ldMySQL=MySQL_$(date -d -1day +”%Y%m%d”).tar.gz

ldWeb=Web_$(date -d -1day +”%Y%m%d”).tar

cd /home/backup/

/usr/bin/ftp -v -n $FTP_IP << EOF

user $FTP_USER $FTP_PASS

type binary

put $MySQLBakName

put $WebBakName

delete $OldMySQL

delete $OldWeb

bye

EOF

rm -rf /home/backup/*.tar*

【Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份】相关文章:

1.windows下计划任务自动备份mysql数据库方法Windows服务器操作系统

下载word文档
《Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份.doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度: 评级1星 评级2星 评级3星 评级4星 评级5星
点击下载文档

文档为doc格式

Linux下自动备份文件到远程FTP服务器并删除指定日期前的备份相关文章
最新推荐
猜你喜欢
  • 返回顶部