您的位置:首页 > 运维架构 > Linux

Linux ftp 自动上传备份文件脚本

2011-02-09 16:04 756 查看
DB 用RMAN 直接将备份文件放在盘柜上了,为了以防万一,老大让把这些备份文件在copy到一个备份服务器上。 RMAN 对目录有严格的要求,以后如果要恢复,还是还原到相同的目录。
之前我计划是将备份服务器共享之后,直接mount 到DB 服务器上,然后在cp 过去,这样是很简单的。但是搞系统的大哥建议用ftp来实现。 当时说是不会出现不能umount的情况,还有啥是安全什么得,这个新年一过也记不清了。 备份服务器上安装了Server-U 的FTP 服务,配置好之后,把备份文件传过来就可以了。

参考:
Linux 终端访问 FTP 及 上传下载 文件
http://blog.csdn.net/tianlesoftware/archive/2010/08/18/5818990.aspx

Linux find 命令 -exec 参数说明
http://blog.csdn.net/tianlesoftware/archive/2011/02/09/6175439.aspx


三步实现:
(1). 查找符合要求的文件,放到一个临时文件夹。
(2). 在ftp中使用mput 上传,上传完从临时文件夹中删除。
(3). 在备份服务器上做好删除策略。不然空间会撑满掉。

三点说明:
(1). 如果说只保留2天的话倒简单,在mput 之前用mdelete 把文件全部删除掉,在上传就可以了,因为我这里要保留多天的记录。 所以就只能在备份服务器上在弄个批处理的计划任务来删除了。
(2). mput 的时候有个问题,它会要求按下回车后在上传, 这对自动脚本来说是非常麻烦的。 我们需要关闭这个指令。

ftp>prompt
切换交谈式指令,使用mput/mget 时不用每个文件皆询问yes/no
ftp> help prompt
prompt force interactive prompting on multiple commands
ftp> prompt
Interactive mode off.
ftp> prompt
Interactive mode on.
ftp> prompt
Interactive mode off.
ftp>

不加任何参数就可以进行开发或关闭的设备,每执行一次,状态就会改变。

(3) find -mtime 参数说明
find /u01/backup/backupsets -mtime +1 -name "*" :+号 表示 1天前的文件
find /u01/backup/backupsets -mtime -1 -name "*" :表示1天内的文件


完整脚本:

Linux上传脚本:
[xezf@localhost scripts]$ cat uploadbackup.sh
#!/bin/sh
find /u01/backup/backupsets -mtime -1 -name "*" -exec cp -f {} /u01/backup/backuptmp /;
ftp -n 192.168.88.251 << EOF
user user password
bin
lcd /u01/backup/backuptmp
prompt
mput *
bye
EOF
cd /u01/backup/backuptmp
rm -rf /u01/backup/backuptmp/*

将uploadbackup.sh脚本添加到crontab,定时执行。 关于crontab,参考我的Blog:
Linux Crontab 定时任务 命令详解
http://blog.csdn.net/tianlesoftware/archive/2010/02/21/5315039.aspx


备份服务器删除脚本:

deletebackupfile.bat
forfiles /p E:/db_backup_history/xezf /m * /d -10 /c "cmd /c del @file"

将这个bat 文件添加到计划任务,定时执行即可。我这里保留的是10天。


在自己的本本上测试没有问题。 找个测试库跑几天看看。 没问题在搬到生产库上去。
补充一句,具体情况具体对待。




------------------------------------------------------------------------------
Blog: http://blog.csdn.net/tianlesoftware
网上资源: http://tianlesoftware.download.csdn.net
相关视频:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx
DBA1 群:62697716(满); DBA2 群:62697977(满)
DBA3 群:62697850 DBA 超级群:63306533;
聊天 群:40132017
--加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: