ssh记住密码自动登录,clone session

1,安装必备软件
基本工具
$sudo apt-get install ssh-client

自动化应答工具
$sudo apt-get install expect

2,登录脚本
利用expect建立一个ssh登录自动应答脚本
$vi sshHostWithUsernameAndPassword

填入下面的内容
#!/usr/bin/expect
# This script needs one argument to(s) connect to remote server:
# host = IP Addreess of remote UNIX server, no hostname
# For example:
#  ./sshadmin 192.168.1.11 admin admin
#set Variables
set host [lrange $argv 0 0]
set username [lrange $argv 1 1]
#support to compose produce env password with static part and dynamic part
set password [lrange $argv 2 3]
spawn ssh $username@$host
expect {
#if need check hostkey, send yes
       -re ".*Are.*.*yes.*no.*" {
       send "yes\r"
       exp_continue
       #look for the password prompt
       }
       "*assword:" {
       send -- "$password\r"
       #the expect command will now return
       }
}
#using 'interact' to stop execute spawn
interact;



3,登录的alias
$vi .bash_aliases

添加
alias sshHost1="sshHostWithUsernameAndPassword yourhost yourUsername yourPassword"

然后
$. .bash_aliases
$sshHost1

就能用ssh免输入账号密码来登录服务器了
赶紧体验吧

如果有动态密码,那
$vi .bash_aliases

添加
alias sshHost2Dynamic="sshHostWithUsernameAndPassword yourhost yourUsername yourStaticPassword"
$sshHost2Dynamic yourDynamicPassword

就可以了(通过sshHostWithUsernameAndPassword的“set password [lrange $argv 2 3]”来组合)

4,clone session
是不是很羡慕secureCRT里的clone session的方式来重用同一个连接,避免第二次登录还要输入密码?其实这个就是ssh内置功能,我们只要按下面设置一下就好了。
创建文件
$vi ~/.ssh/config

在config的文件中,添加如下内容:
host *
ControlMaster auto
ControlPath ~/.ssh/master-%r@%h:%p


然后
$vi ~/.bash_aliases

添加(后面不需要密码了)
alias sshHost2DynamicClone="sshHostWithUsernameAndPassword yourhost yourUsername"
$. ~/.bash_aliases


第一次登录
$sshHost2Dynamic yourDynamicPassword

后面再登录
$sshHost2DynamicClone

就可以登录了

同时我们发现~/.ssh/目录下有master-*的sock文件,就是它记录了我们目前登录到的机器,这样的话,我们登录同样的机器就会重用同一个session了。
其他linux发行版的同学应该都可以使用,毕竟这只是个ssh的客户端配置文件。

config文件的详细介绍可以参考:

http://linux.die.net/man/5/ssh_config

猜你喜欢

转载自xuhuandh.iteye.com/blog/947039