Linux下脚本实现交互输入

需要处理的问题是:

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/expectset orgpath [lindex $argv 0 ]set target [lindex $argv 1 ]spawn ssh admin@10.20.151.5expect “.*password:”send “log2011\n”expect “].*”send “mkdir -p $target\n”expect “].*”send “exit\n”#interact spawn scp -r $orgpath admin@10.20.151.5:$targetexpect “.*password:”send “log2011\n”expect eofexit

#scp Hadoop1的按小时分析的结果文件,,采样获取10点和22点文件到开发环境151.5for 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.5for 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_dirdone##################### Linux下脚本实现交互输入举例结束 #####################

你曾经说,最大的愿望,

Linux下脚本实现交互输入

相关文章:

你感兴趣的文章:

标签云: