ssh自动连接(expect)

来源:互联网 发布:读书笔记 知乎 编辑:程序博客网 时间:2024/04/30 08:50

 

 

昨天廖老师让尝试使用ssh脚本进行远程控制,但是这个东西需要手动去输入密码,不能放到后台去执行,于是就考虑有没有办法让他自动输入密码呢,经过查阅。最终发现了expect这个东西,很强大的东西,所以我就在本地测试了下,最终实现了不用手动输入密码也可以进行远程连接。不仅在ssh连接中可以用到,以后任何需要输入密码或者输入命令的,都可以,不仅保持了该软件的安全保密性又实现了智能性。拿来与大家分享.

 

        要使用expect需要预先安装tcl这个东西,然后再安装expect.我这里使用的是tcl8.4.13-src.tar.gzexpect-5.43.0.tar.gz的安装包.下载后,放在/home目录下:

 

安装tclexpect

  

   #tar zxvf tcl8.4.3-src.tar.gz

   #cd tcl8.4.13

   #./configure && make && make install

   #cp tclUnixPort.h  ../generic/

  

   #tar zxvf expect-5.43.0.tar.gz

   #cd expect-5.43/

   #./configure --with-tcl=/usr/local/lib/ --with-tclinclude=/

     /home/tcl8.4.11/generic/  --with-x=no

   #make && make install

  

介绍几个命令的含义:

1. send

用来发送一个字符串,比如 send "hello world"

初始情况下,这个字符串会发送到标准输出。如果你用的是max OSX或者linux,可以在Terminal下直接输入expect命令并回车,就进入了expect交互环境,此时,输入send "hello world"就可以看到结果。

一旦你的程序已经与其他程序进行交互,字符串就会被发送到其他程序那里。如上面的例子脚本中,我们调用send ”$password/r"就是把密码发送给SSH连接的服务器端指定端口。

 

2. expect

send相反,expect用来等待你所期望的字符串。比如expect "hello"expect后面跟的字符串中,你可以指定一个正则表达式。expect会一直等待下去,除非收到的字符串与预期的格式匹配,或者到了超期时间。

 

3. spawn

spawn用来启动一个新的进程,比如上面的spawn ssh -D $port $user@$hostExpect会执行命令“ssh -D $port $user@$host”

在交互式的场景中,当你输入命令后,可能服务器端会返回一些操作提示符,以让你输入命令。Expect提供了这样三个常用的命令,spawn, expectsend,恰好满足这种需要。把它们结合起来使用,可以实现很多简单的自动化脚本。

其它常用的命令还有:interact,比如你通过脚本自动连接到了某个ftp,并输入了用户名密码,此时需要人工输入一些命令,就可以使用interact命令,它会把脚本的控制权交给用户;sleep,等待多少秒等等。

     由于expect是从Tcl继承下来的,所以也支持Tcl的语法和命令,比如变量声明、流程控制等等。

 

 

 OK,tcl以及expect已经安装完成了.下面给出scp的一个expect很简单的一个脚本

 

一个简单的小例子:

#!/usr/local/bin/expect -f

 

set user root

set host 172.20.10.200

set password 111111

set timeout -1

 

spawn ssh  $user@$host

    expect "*password:*"

send "$password/r"

expect eof