Linux实现SSH免密登录

环境准备:

  • 192.168.58.148 客户端
  • 192.168.58.150 服务端

功能实现:

第一步在150机器上生成公钥:(默认就好)

[root@nginx1 ~]# ssh-keygen -t rsa -b 4096
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Created directory '/root/.ssh'.
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa
Your public key has been saved in /root/.ssh/id_rsa.pub
The key fingerprint is:
SHA256:r9Ct7hQZOtVGahJlpv1YUjHTBFDU3Xpsl925LQDHjSI root@nginx1
The key's randomart image is:
+---[RSA 4096]----+
|      ..=+XB.+ . |
|       *E=oo* o .|
|      o B.++   o=|
|       = O  . .oB|
|      o S .  . o+|
|       o +    ...|
|      . o o    . |
|       o o       |
|       o=        |
+----[SHA256]-----+

第二步将公钥写入到文件~/.ssh/authorized_keys中·

[root@nginx1 ~]# vim ~/.ssh/authorized_keys
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC5POWAdc6VeD3LBbGp67XeFZy7wk7NyQFuDGnQ7ZBjtHEzf320oLgD91/ZFJqSPCjUFMsQPHliq1dVd1rOQZ4YB+KakkTywIYWow3nPbx5DuXZN9v2k4xuyHepsLbHC0mMqNs73P1vpxARKaU2xmlqZDTMkcjA6iPF0ujOLuCmsoAbu6oatoqe2t/9bV6E+a2o/2xliXE1/Ko5X9HQTAa+OEGVHUI5Z8y+WfnUKHPOUZI0cMSKhPYREaWisFVMGQZ7mvbec7DNIrf/Rb678QRa5oWUq02Y1ERei2d4xVS7zDvNuj2MPHwFNNvz8m6FxPvBzC3M3cYwDQ4iYb2mFX7uMfQo0cJ/zG0GrTHkb2wJsCVcAojyvXNGMnfKyav7UnYMGNlnZTWAPZ0QO1+A/BBL4uoeSOIkCwT5Prtosc1KpcbSN02wwMATnBzjVWmCGwo0R/8TbLa+r4JYXW+Lhz8nIZ5YEyc0CGqX0rYMw/WxcJJko8AaCQs1/393/Ev4l4TaoIhIYrkWT3sf45FLA+LxQQvqzzu2AOtXQZiiujgw/Akzd19E7yrTzrzMqSCGcVhR3NuvqSOZFwtUSv8w2+nPdTGkunCvB5Ud+qcJ/ax3zh3zwA8+LcYqnddpUZixYBD/syVt805nnCjRBc1r04hehE5C8EAUc1J0ermypQ== root@nginx1

第三步在148机器上使用命令ssh-copy-id -i ~/.ssh/id_rsa.pub root@192.168.58.150将公钥拷贝到150机器上

[root@nginx2 ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub root@192.168.58.150
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
The authenticity of host '192.168.58.150 (192.168.58.150)' can't be established.
ED25519 key fingerprint is SHA256:iRElSaP/Ey7gHz9NeGQCU1u2Cpg31m7ydRY1xAiJAjI.
This key is not known by any other names
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys

Authorized users only. All activities may be monitored and reported.
root@192.168.58.150's password: 

Number of key(s) added: 1

Now try logging into the machine, with:   "ssh 'root@192.168.58.150'"
and check to make sure that only the key(s) you wanted were added.

第四步测试连通性

[root@nginx2 ~]# ssh root@192.168.58.150

Authorized users only. All activities may be monitored and reported.

Authorized users only. All activities may be monitored and reported.
Last login: Mon Aug 19 12:35:08 2024 from 192.168.58.1


Welcome to 5.10.0-136.12.0.86.oe2203sp1.x86_64

System information as of time: 	Tue Aug 20 06:48:24 AM CST 2024

System load: 	0.00
Processes: 	135
Memory used: 	43.0%
Swap used: 	1.1%
Usage On: 	14%
IP address: 	192.168.58.151
Users online: 	3


[root@nginx1 ~]# 
logout

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Linux实现SSH免密登录,你可以按照以下步骤进行操作: 1. 生成SSH密钥对:在本地计算机上打开终端,并运行以下命令生成密钥对: ``` ssh-keygen -t rsa ``` 这将生成一个RSA密钥对,包括公钥和私钥。你可以选择使用默认的密钥保存路径和文件名,或者根据需要进行自定义。 2. 将公钥复制到目标服务器:将公钥复制到你希望免密登录的目标服务器上。可以使用以下命令将公钥复制到远程服务器: ``` ssh-copy-id username@remote_host ``` 替换 `username` 为你的目标服务器用户名,`remote_host` 为目标服务器的IP地址或域名。 如果 `ssh-copy-id` 命令不可用,你可以手动复制公钥文件的内容到目标服务器的 `~/.ssh/authorized_keys` 文件中。 3. 配置SSH服务器:确保目标服务器上的SSH服务器已正确配置以允许密钥登录。打开目标服务器上的SSH配置文件 `/etc/ssh/sshd_config`: ``` sudo vi /etc/ssh/sshd_config ``` 确保以下配置项被启用: ``` PubkeyAuthentication yes PasswordAuthentication no ``` 4. 重新启动SSH服务:保存并关闭SSH配置文件后,使用以下命令重新启动SSH服务: ``` sudo service ssh restart ``` 或者,如果你的系统使用 `systemd`,可以使用以下命令: ``` sudo systemctl restart sshd 5. 测试免密登录:现在,你可以尝试使用SSH连接到目标服务器,如果一切设置正确,你应该无需输入密码即可成功登录: ``` ssh username@remote_host ``` 替换 `username` 为你的目标服务器用户名,`remote_host` 为目标服务器的IP地址或域名。 这样,你就成功实现了在Linux上的SSH免密登录。请记得保护好私钥文件,不要泄露给他人,以确保系统的安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

元气满满的热码式

感谢您的支持!我会继续努力发布

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值