linux脚本 scp 管道,shell脚本实现scp文件传输

#!/bin/basha=$1b=$2ip=$3port=$4passwd=$5/bin/rpm -qa|/bin/grep -q expectif [ $? -ne 0 ];then        echo "please install expect"        exitfiif [ $# -ne 5 ];then        echo "must 5 parameter,1:source file,2:object file,3:object ip 4:object port,5:passwd"        exitfiexpect -c "  spawn scp -P $port $a root@$ip:$b  expect {    \"*assword\" {set timeout 300; send \"$passwd\r\";}    \"yes/no\" {send \"yes\r\"; exp_continue;}  }  expect eof"

==================================================

scp是一个基于ssh的Linux环境下传输文件的好工具,但是使用shell脚本调用scp时会面临一个问题,即scp强制要求通过交互方式输入密码,而不像mysql等拥有-u -p选项。下面有两种方法帮助shell脚本跨过输入密码这个障碍。

1.建立机器间完全信任关系

假设需要从机器A传输文件至机器B

1)在机器A上运行

# ssh-keygen -t rsa

上述命令会在~/.ssh/目录生成私钥证书id_rsa和公钥证书id_rsa.pub;

2)将公钥证书id_rsa.pub复制到机器B的用户根目录的.ssh子目录中,再将文件内容append到文件authorized_keys中。

其实只要用一条单行命令就可以完成步骤2,它被commandlinefu.com的用户投票选为十大最酷的Linux单行命令之一:

ssh-copy-id  [-i [identity_file]]  [user@]machine

identity_file是公钥证书的路径,默认情况下是~/.ssh/id_rsa.pub.

如果要建立双方向的完全信任关系,还要从机器B到机器A再重复一遍上面的操作。

不过这样的方法并不完美,一是运维成本太高,二是机器间的安全屏障完全消失,安全代价太大,所以本人强烈推荐第二种方法。

2.expect脚本

expect脚本是一种建立在tcl基础上的脚本语言,曝光率不高,却堪称shell脚本的好×××。expect脚本为交互而生,被设计为专门针对交互式程序的工具,常与对telnet、ftp、fsck、rlogin、tip、scp等配合使用。例如:

#!/usr/bin/expectspawn scp -P 22 20111111.log root@192.168.0.1:/log/expect {  "*assword" {set timeout 300; send "passwd\r";}  "yes/no" {send "yes\r"; exp_continue;}}expect eof 上面是一个独立的expect脚本文件,如果像把这段脚本嵌入其它shell脚本中就要用到expect -c

#!/bin/bashexpect -c "  spawn scp -P 22 20111111.log root@192.168.0.1:/log/  expect {    \"*assword\" {set timeout 300; send \"passwd\r\";}    \"yes/no\" {send \"yes\r\"; exp_continue;}  }  expect eof"这段脚本的含义是监听scp命令,如果输入包含*assword,则输入密码“passwd”;如果输入包含yes/no,输入yes并继续进行交互(exp_continue)。

注:两个用户第一次scp连接时会提示“… Are you sure you want to continue connecting (yes/no)? …”,所以要考虑yes/no的情况。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值