用自动wget或ftp提高工作效率

类别:编程语言 点击:0 评论:0 推荐:
2004-06学会用wget工具来取FTP站点的文件.

wget ftp://username:password@ip_address/dir/file_name

比自动FTP的SHELL脚本的方法方便多了.

例如获取FTP服务器上文件名是昨天日期的文件,如filename_20040608_001,filename_20040608_002,......

#!/bin/sh
rq=`date --date '1 days ago' "+%Y%m%d"`
wget -q ftp://username:password@ip_address/filename_$rq*

有的时候,FTP站点用wget可以进行目录浏览,也可以下载固定文件名的文件,
却不能把文件名是昨天日期的文件取下来时.

我想了一个方法:

#!/bin/sh
rq=`date --date '1 days ago' "+%Y%m%d"`
wget -nr ftp://username:password@ip_address/filename_$rq*
grep filename_$rq .listing > 1.txt
cat 1.txt|while read LINE
do
        file_name=`echo $LINE|awk '{print $9}'`
        wget -q ftp://username:password@ip_address/$file_name
done

原理是在目录浏览.listing文件里查找到昨天生成的文件名到临时文件1.txt里

-rw-r--r--    1 fengyu   fengyu     106880 Jun  9 11:44 file_name_20040608001
-rw-r--r--    1 fengyu   fengyu     161760 Jun  9 11:44 file_name_20040608002
...... ...... ......

从头到尾一行行读这个1.txt文件,取它的第9段,也就是固定的文件名,再传递给wget工具.

-------------------------------------------------------------------------------------

2003-01时候看从www.china-pub.com下载的书《LINUX与UNIX Shell编程指南》,不经意的发现有一个写成

    自动FTP的SHELL脚本,结合数据库的系统管理,它有很多用途,可以提高你的工作效率。
   
    用途1: 把数据库的逻辑备份或者其它关键的文件传到另一个地区,实现远端备份。
   
    ( 例如:从北京机房的传到上海机房。)
          
    auto_ftp.sh 内容如下:
   
#!/usr/bin/sh
ftp -i -n 192.168.0.253 <<FTPIT
user username password
bin
put /oracle_backup/exp/user1.dmp.Z /bk/oracle_bak/dmp/user1.dmp.Z
put /oracle_backup/exp/user2.dmp.Z /bk/oracle_bak/dmp/user2.dmp.Z
quit
FTPIT

你可以根据实际情况修改斜体字的内容:
    目标服务器的IP地址,ftp用户名和密码,put或者get传递方式,源目录文件和目标目录文件。
   
用途2: 使远端节点间有规律的数据库导出并导入的工作自动进行。

    按时间顺序在源服务器执行exp_tables.sh,然后auto_ftp_tables.sh。
   
    接着在目标服务器执行drop_tables.sh,最后imp_tables.sh。
   
    如何设置时间表并自动执行,请参看 UNIX下让ORACLE定时执行*.sql文件。
   
    用途3: 把自动生成的压缩格式的报表文件传到Linux邮件服务器,由机器自动给相关人员发EMAIL。
   
    auto_mail.sh 内容如下:
   
    $(cat mail.txt; uuencode report1.txt report2.txt ) | mail [email protected]
   
    说明:mail.txt为邮件正文的内容,report1.txt.Z report2.txt.Z为邮件的两个附件,
   
          [email protected]为邮件的收件人。

本文地址:http://com.8s8s.com/it/it24100.htm