感谢支持
我们一直在努力

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

赞(0) 打赏
转载请注明出处:服务器评测 » Linux下脚本实现交互输入
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏