自动ssh登录的几种方法
作者 佚名技术
来源 Linux系统
浏览
发布时间 2012-05-16
原文地址 [url]http://bbs.linuxpk.com/viewthread.php?tid=9327[/url]
自动ssh登录的几种方法
1. 自动ssh/scp方法== A为本地主机(即用于控制其他主机的机器) ; B为远程主机(即被控制的机器Server), 假如ip为192.168.60.110; A和B的系统都是Linux 在A上运行命令: # ssh-keygen -t rsa (连续三次回车,即在本地生成了公钥和私钥,不设置密码) # ssh root@192.168.60.110 "mkdir .ssh" (需要输入密码) # scp ~/.ssh/id_rsa.pub root@192.168.60.110:.ssh/id_rsa.pub (需要输入密码) 在B上的命令: # touch /root/.ssh/authorized_keys (如果已经存在这个文件, 跳过这条) # cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys (将id_rsa.pub的内容追加到authorized_keys 中) 回到A机器: # ssh root@192.168.60.110 (不需要密码, 登录成功) 2. 控制n个机器如上所述自动登录 那就需要n对钥匙(密钥和公钥), ssh-keygen 命令可以随意更改钥匙对的名字, 比如: # ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsa_192.168.60.110 这样私钥和公钥的名字分别就是: id_rsa_192.168.60.110和 id_rsa_192.168.60.110.pub;然后将 id_rsa_192.168.60.110.pub 文件的内容, 追加到sever的 ~/.ssh/authorized_keys文件中,, 在本地用ssh命令的 -i 参数指定本地密钥, 并登录: # ssh -i /root/.ssh/id_rsa_192.168.60.110 someone@192.168.60.110 scp也是一样的 # scp -i /root/.ssh/id_rsa_192.168.60.110 filename someone@192.168.60.110:/home/someone 在文件.bashrc中加下两行,每次做同样的操作就不用敲入这样长的命令了: alias sshcell=''ssh -i /root/.ssh/id_rsa_192.168.60.110 someone@192.168.60.110'' alias scpcell=''scp -i /root/.ssh/id_rsa_192.168.60.110 filename someone@192.168.60.110:/home/someone''
这样,直接键入一下指令实现ssh和scp自动登录: # sshcell # scpcell 3. 自动ssh/scp脚本 如果需要从A,到B,然后才能够到C,那么需要ssh和scp两次,是比较麻烦的. ssh自动登录: #!/usr/bin/expect -f set timeout 30 spawn ssh weiqiong@B expect "password:" send "ppppppr" expect "]*" send "ssh weiqiong@Cr" expect "password:" send "ppppppr" interact scp从A拷贝文件到C: #!/usr/bin/expect -f set timeout 300 set file [lindex $argv 0] spawn scp $file weiqiong@B:/home/weiqiong expect "password:" send "ppppppr" expect "]*" spawn ssh weiqiong@B expect "password:" send "ppppppr" expect "]*" send "scp $file weiqiong@C:/home/weiqiongr" expect "password:" send "ppppppr" expect "]*" exit interact scp从C拷贝文件到A: #!/usr/bin/expect -f set timeout 300 set file [lindex $argv 0] spawn ssh weiqiong@B expect "password:" send "ppppppr" expect "]*" send "scp weiqiong@C:/home/weiqiong/$file .r" expect "password:" send "ppppppr" expect "]*" send "exitr" expect "]*" spawn scp weiqiong@B:/home/weiqiong/$file . expect "password:" send "ppppppr" interact 4. 建立ssh/scp通道 比如说我的机器是A,中间服务器为B,目标服务器是C<br> 从A可以ssh到B,从B可以ssh到C,但是A不能直接ssh到C<br> 现在展示利用ssh通道技术从A直接传输文件到C<br> 1. ssh -L1234:C:22 userid@B<br> input B''s password<br> (1234是本机A的空闲端口,该指令需要A机器上的root用户权限,实际上是在本机1234端口建立了一个通道)<br> 2. 打开一个新的console,键入:<br>
scp -P1234 filename userid@localhost:<br> input C''s password
|
|||
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: linux 防火墻生成器shorewall下一篇: 一个更换ip的sh
关于自动ssh登录的几种方法的所有评论