`

【转】自动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整合 5种方式

    然而,本文探讨的“SSH整合5种方式”并非指SSH协议本身的五种使用方法,而是指如何将SSH与Spring框架进行整合的五种策略。Spring框架是Java平台上的一个开源框架,用于构建企业级应用程序,它提供了丰富的功能,包括...

    ssh注册登录项目

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络上提供安全的远程登录和其他服务。在这个"SSH注册登录项目"中,我们很显然关注的是使用SSH进行用户身份验证和建立安全连接。SSH广泛应用于系统管理员远程管理...

    基于SSH实现登录的Demo

    在IT领域,SSH(Secure Shell)是一种网络协议,用于安全地远程登录到服务器,执行命令,传输文件等。本文将详细讲解如何基于SSH实现登录功能,并构建一个基础的SSH框架。 首先,SSH提供了加密的网络通信,确保了...

    SSH使用方法.pdf

    SSH使用方法主要涉及以下几个方面: 1. 选用SSH管理软件 在文档中提到了选用Putty软件进行SSH管理。Putty是一个流行的SSH和Telnet客户端,它允许用户通过图形用户界面与远程服务器进行安全连接。Putty支持多种网络...

    批量实现ssh无密码登录

    通过以上两种方法,我们可以有效地在多台服务器之间建立起SSH无密码登录的信任关系。方法一适合处理数量不多的服务器,而方法二则更适合大规模部署。无论采用哪种方式,都能够极大地提升运维效率,减少重复劳动,...

    ssh jail 笼环境自动部署

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络上提供安全的远程登录和其他服务。Jail或Jailkit是Linux系统中的安全措施,它允许管理员创建受限的用户环境,防止恶意活动对整个系统的破坏。SSH jail环境是...

    基于ssh框架的登录注册系统

    这个基于SSH框架的登录注册系统是为初学者和开发者提供的一种基础实践平台,用于理解并掌握如何在实际项目中应用这些框架。下面我们将深入探讨SSH框架的核心组件及其在登录注册系统中的应用。 **Struts2** 是一个...

    Linuxssh登录远程服务器 expect

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络环境中提供安全的远程登录功能。它允许用户通过命令行界面连接到远程服务器,执行各种管理任务。而 Expect 是一个自动化脚本工具,专门设计用来自动化那些...

    SSH代码自动生成器

    SSH代码自动生成器的主要功能可能包括以下几点: 1. **SSH连接配置**:用户可以输入服务器地址、端口号、用户名和密码,工具会自动生成相应的SSH连接配置代码,如在Python中使用`paramiko`库的代码片段。 2. **...

    ssh免密码登录

    如果遇到无法登录的情况,有几种常见解决策略: **方法一:权限调整** 确保`authorized_keys`文件具有正确的权限。运行以下命令: ``` chmod 700 ~/.ssh/ chmod 600 ~/.ssh/authorized_keys ``` 并临时关闭SELinux...

    ssh代码自动生成器

    SSH代码自动生成器的工作原理通常包括以下几个步骤: 1. **项目配置**:用户输入项目的基本信息,如项目名称、包结构、数据库连接等,这些信息将被用于生成对应的代码结构。 2. **模型定义**:用户定义或导入...

    (转)SSH项目编写规范示例

    SSH(Struts2 + Spring + Hibernate)是一种经典的Java Web开发框架组合,用于构建高效、可扩展的企业级应用程序。本文将围绕SSH项目编写规范,详细阐述如何有效地组织代码、设计架构以及遵循最佳实践。 首先,...

    SSH简介及配置使用SSH登陆远程主机讲义

    SSH,全称Secure Shell,是一种网络协议,用于在不安全的网络环境中提供安全的远程登录和其他网络服务。它由Tatu Yloenen开发,最初是为了替代像FTP、POP和telnet这类明文传输数据的不安全协议。SSH通过加密技术确保...

    Python自动连接ssh的方法

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

    ssh远程执行脚本

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络上提供安全的远程登录和其他服务。在这个场景中,我们讨论的是如何使用SSH来远程执行脚本,特别是在多台Linux服务器之间进行批量操作。这个过程通常涉及到几...

    基于SSH2组合框架下办公自动化系统

    ### 基于SSH2组合框架下的办公自动化系统设计与研究 #### 一、引言 随着互联网技术的快速发展和Java语言的不断成熟优化,基于JavaWeb的应用因其易用性、通用性和良好的可扩展性等特点而迅速成为各类信息系统的主要...

    ssh 简单实用的ssh项目

    SSH,全称Secure Shell,是一种网络协议,用于在不安全的网络环境中提供安全的远程登录和其他服务。在IT行业中,SSH常被用作Linux或Unix系统中的远程控制工具,允许用户安全地执行命令、传输文件等操作。在这个“ssh...

    SSH Secure Shell Client用public key认证登录.docx

    公钥认证是SSH的一种安全登录方法,其中用户拥有一个公钥和对应的私钥对。下面将详细讲解如何使用SSH Secure Shell Client进行公钥认证登录以及相关配置。 首先,要在SSH Secure Shell Client中生成一个新的公钥对...

    C#版SSH、SCP,可作为客户端连结LINUX源码

    SSH是一种网络协议,用于安全地远程登录到服务器,执行命令和传输文件,而SCP是基于SSH的安全文件传输协议。 描述中提到,这个源码包可以直接使用,包含十几个DEMO(演示程序),涵盖了SSH和SCP的各种功能。用户...

Global site tag (gtag.js) - Google Analytics