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/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下脚本实现交互输入举例结束 #####################

相关内容