linux sshd自动登录,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

从A可以ssh到B,从B可以ssh到C,但是A不能直接ssh到C

现在展示利用ssh通道技术从A直接传输文件到C

1. ssh -L1234:C:22 userid@B

input B's password

(1234是本机A的空闲端口,该指令需要A机器上的root用户权限,实际上是在本机1234端口建立了一个通道)

2. 打开一个新的console,键入:

scp -P1234 filename userid@localhost:

input C's password0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux系统中,SSH(Secure Shell)是一种安全的远程登录协议,可以通过SSH协议在本地和远程服务器之间建立加密的通信连接。下面是Linux系统下载安装SSH的步骤: 1. 打开终端:在Linux系统中,可以通过快捷键Ctrl+Alt+T打开终端。 2. 检查是否已经安装了SSH:在终端中输入以下命令并按下回车键: ``` ssh -V ``` 如果已经安装了SSH,将显示SSH的版本信息。如果没有安装,将提示找不到该命令。 3. 安装SSH:如果没有安装SSH,可以使用包管理器来安装。不同的Linux发行版使用不同的包管理器,以下是几个常见的发行版和对应的包管理器: - Ubuntu/Debian:使用apt-get命令安装,执行以下命令: ``` sudo apt-get install openssh-server ``` - CentOS/Fedora:使用yum命令安装,执行以下命令: ``` sudo yum install openssh-server ``` - Arch Linux:使用pacman命令安装,执行以下命令: ``` sudo pacman -S openssh ``` 4. 启动SSH服务:安装完成后,可以使用以下命令启动SSH服务: - Ubuntu/Debian: ``` sudo service ssh start ``` - CentOS/Fedora: ``` sudo systemctl start sshd ``` - Arch Linux: ``` sudo systemctl start sshd ``` 5. 配置SSH:默认情况下,SSH的配置文件位于`/etc/ssh/sshd_config`。你可以根据需要修改配置文件,例如更改SSH的监听端口、禁用密码登录等。修改完成后,需要重启SSH服务使配置生效。 现在你已经成功下载安装了SSH,并可以使用SSH客户端连接到远程服务器。如果你有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值