`

【转】自动ssh登录的几种方法

阅读更多

本文转自 http://blueicer.blog.51cto.com/395686/88175

 

自动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 "pppppp\r"
expect "]*"
send "ssh weiqiong@C\r"
expect "password:"
send "pppppp\r"
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 "pppppp\r"
expect "]*"
spawn ssh weiqiong@B
expect "password:"
send "pppppp\r"
expect "]*"
send "scp $file weiqiong@C:/home/weiqiong\r"
expect "password:"
send "pppppp\r"
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 "pppppp\r"
expect "]*"
send "scp weiqiong@C:/home/weiqiong/$file .\r"
expect "password:"
send "pppppp\r"
expect "]*"
send "exit\r"
expect "]*"
spawn scp weiqiong@B:/home/weiqiong/$file .
expect "password:"
send "pppppp\r"
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
分享到:
评论

相关推荐

    ssh自动登录的4种实现方法

    主要介绍ssh自动登录的几种实现方法,需要的朋友可以参考下

    Python自动连接ssh的方法

    本文实例讲述了Python自动连接ssh的方法。分享给大家供大家参考。具体实现方法如下: #!/usr/bin/python #-*- coding:utf-8 -*- import sys, time, os try: import pexpect except ImportError: print """ You ...

    java项目代码生成器

    ssm+dubbox+angularjs等多种模板的代码自动生成,可以极大提高开发效率,秒杀一切单表操作,支持oracle+mysql多数据库,开发人员必备工具,现提供给广大开发人员 选择你的数据库,然后就可以根据字段生成增删改查代码,再...

    ssh员工管理系统.zip

    Java是一种高性能、跨平台的面向...自动内存管理(垃圾回收): Java具有自动内存管理机制,通过垃圾回收器自动回收不再使用的对象,使得开发者不需要手动管理内存,减轻了程序员的负担,同时也减少了内存泄漏的风险。

    ssh(structs,spring,hibernate)框架中的上传下载

    Spring针对几个著名的Web服务器的数据源提供了相应的JDBC抽取器:  •WebLogic:WebLogicNativeJdbcExtractor  •WebSphere:WebSphereNativeJdbcExtractor  •JBoss:JBossNativeJdbcExtractor  在定义了JDBC...

    玩转模板--自动代码生成工程

    第二种方法: 将该文件作为模板,直接在上面用模板语言书写要插入的代码片段,每次解析完这个模板片段后,再插入这段模版,如此往复.而这些模板片段可以包含在编译语言 的注释块中(不是模版语言的注释块),不会对应用...

    ssh框架实现的员工信息管理系统.zip

    Java是一种高性能、跨平台的面向...自动内存管理(垃圾回收): Java具有自动内存管理机制,通过垃圾回收器自动回收不再使用的对象,使得开发者不需要手动管理内存,减轻了程序员的负担,同时也减少了内存泄漏的风险。

    Linux ssh远程连接断开问题处理办法解决

    我们在通过远程连接操作Linux server的时候,有...关于这个问题,下面有几种解决办法,供参考: echo TMOUT=600 &gt;&gt; ~/.bashrc 或 echo TMOUT=600 &gt;&gt; /etc/profile 设置一个超时的秒数,600秒后终端上没有任何操作便

    springMVC Hibernate (ssh) 留言板管理系统.zip

    Java是一种高性能、跨平台的面向...自动内存管理(垃圾回收): Java具有自动内存管理机制,通过垃圾回收器自动回收不再使用的对象,使得开发者不需要手动管理内存,减轻了程序员的负担,同时也减少了内存泄漏的风险。

    基于SSH框架的外卖点餐系统(个人毕业设计)。.zip

    Java是一种高性能、跨平台的面向...自动内存管理(垃圾回收): Java具有自动内存管理机制,通过垃圾回收器自动回收不再使用的对象,使得开发者不需要手动管理内存,减轻了程序员的负担,同时也减少了内存泄漏的风险。

    基于SSH框架的BOS物流管理系统,eclipse+maven+svn+powerdesigner.zip

    Java是一种高性能、跨平台的面向...自动内存管理(垃圾回收): Java具有自动内存管理机制,通过垃圾回收器自动回收不再使用的对象,使得开发者不需要手动管理内存,减轻了程序员的负担,同时也减少了内存泄漏的风险。

    Centos7下用户登录失败N次后锁定用户禁止登陆的方法

    针对linux上的用户,如果用户连续3次登录失败,就锁定该用户,几分钟后该用户再自动解锁。Linux有一个pam_tally2.so的PAM模块,来限定用户的登录失败次数,如果次数达到设置的阈值,则锁定用户。 PAM的配置文件介绍...

    存放点文件

    存放点文件这些是我用GNU Stow管理的点文件。... 以下是几种方法: 在$HOME有一个git repo 从dotfile仓库复制到位vim local.conf # specify local configurationmake # construct dotfiles to specificationmake

    CuteFTP9简易汉化版

    folders-Mirror同步你的本地驱动器上,远程站点,或者两者都只有几个鼠标点击使用一种上传软件的文件夹同步工具。安排重复连续镜像同步事件的本地和远程文件夹树。您可以监视多个文件夹或同步多个站点的文件夹同步向导...

    一个漏洞扫描器粘合剂,添加目标后30款工具自动调用.zip

    支持 web扫描、系统扫描、子域名收集、目录扫描、主机扫描、主机发现、组件识别、URL爬虫、XRAY扫描、AWVS自动扫描、POC批量验证,SSH批量测试、vulmap。 爬虫(Web Crawler)是一种自动化程序,用于从互联网上收集...

    远程登录软件s-term

    s-term的一大特色是:采用了多文档界面,能在一个框架中打开多个窗口,最小化时能缩小为图标,隐藏在任务栏中,这个功能是别的telnet工具所不具有的,让我这种喜欢多开几个telnet窗口的一看到就爱不释手。...

    校园宿舍管理系统.zip

    基于SSH+easyUI+ActiveMQ+MySQL,。 分为系统管理员、楼宇管理员、学生三种权限。 模块介绍: (1) 学生管理模块 此模块某些部分是对系统管理员、楼宇管理员和学生开放的。 (2) 楼宇管理模块 此模块只可以由系统管理...

    NetTransport 网络传送带

    支援SSL和SSH保证数据传输的安全性,目前就算在国际上也没有几款软件能达到这样的高度。 主要功能列表 内建简易的但功能不弱的文件管理器,帮助用户更好地分类和轻松地组织下载文件。 简单的多用户管理,...

    azure-linux-extensions:适用于AzureLinux虚拟机扩展

    Microsoft Azure IaaSLinux扩展该项目提供...提供几种方法,以允许VM的所有者取回SSH访问权限1.0 允许Azure VM的所有者安装omsagent并将其附加到OMS工作区3.0.129 允许Azure虚拟机的所有者获取Linux虚拟机的诊断数据1.0

    计算机毕业设计-文章发布系统的设计与实现(包含论文+源码)

    本文设计的文章发布系统是一个基于B/S模式,前台界面采用JSP语言编写,后台采用SSH框架来搭建,开发环境使用MyEclipes的系统。该系统充当了一个网络文章发布媒介的功能,实现了系统化、自动化的管理,使人们在任何...

Global site tag (gtag.js) - Google Analytics