需要处理的问题是:
1、scp远程拷贝每个源文件均需要输入密码。源文件是通过正则匹配的,scp支持,但每个文件或目录需要手工输入远程机器的密码,文件大的时候总不能守着吧
可选的解决方案是:打通ssh通道。但我只需要处理一次,原则上生产环境是不打通到开发环境的ssh通道的。事前事后都得联系SA处理,麻烦
2、scp远程拷贝目标目录只能指定一个已存在的目录,不支持动态生成。
比如:scp -r ./*/*c*/*2* admin@10.20.151.5:/home/admin/yunti_compare,这是可以的,只是每次需要手动输入密码,如果我想将目标文件放到:/home/admin/yunti_compare/*,其中*对应源目录的名字呢?搞不定。
最后,使用expect脚本实现交互。如下所示。
如果问题规模更复杂些,特别是文件备份,建议使用:rsync
#################################################### Linux下脚本实现交互输入 ########################################################## #!/usr/bin/expect set orgpath [lindex $argv 0 ] set target [lindex $argv 1 ] spawn ssh admin@10.20.151.5 expect ".*password:" send "log2011\n" expect "].*" send "mkdir -p $target\n" expect "].*" send "exit\n" #interact spawn scp -r $orgpath admin@10.20.151.5:$target expect ".*password:" send "log2011\n" expect eof exit #scp hadoop1的按小时分析的结果文件,采样获取10点和22点文件到开发环境151.5 for buname in `du -sh /data/work/*/SqlldrDat/20111213/10 | awk -F '/' '{print $4}'` do #scp -r /data/work/*/SqlldrDat/20111213/10 admin@10.20.151.5:/home/admin/yunti_compare/hadoop_20111213/*/10 #scp -r /data/work/*/SqlldrDat/20111213/22 admin@10.20.151.5:/home/admin/yunti_compare/hadoop_20111213/*/22 ./copy_log.expect "/data/work/$buname/SqlldrDat/20111213/10" "/home/admin/yunti_compare/hadoop_20111213/$buname" ./copy_log.expect "/data/work/$buname/SqlldrDat/20111213/22" "/home/admin/yunti_compare/hadoop_20111213/$buname" done #scp hadoop1的按天分析文件到开发环境151.5 for buname in AeCtr AuLog CnP4PClick EnP4P EnP4PClick EnWeb InnerClickstat InnerCtr InnerLog MytLog do target_dir="/home/admin/yunti_compare/hadoop_20111213/$buname""_day" ./copy_log.expect "/data/work/$buname/SqlldrDat/20111213" $target_dir done ################################################### Linux下脚本实现交互输入举例结束 #####################################################