服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - Linux如何设置ssh密钥(免密码)登录

Linux如何设置ssh密钥(免密码)登录

2023-09-14 17:11未知服务器之家 Linux

我们在使用ssh客户端远程连接Linux服务器时,为了考虑安全方面的因素,通常使用密钥的方式来登录。密钥分为公钥和私钥,这两把密钥可以互为加解密。公钥是公开的,私钥是由个人自己持有,并且必须妥善保管和注意保密。

我们在使用ssh客户端远程连接Linux服务器时,为了考虑安全方面的因素,通常使用密钥的方式来登录。密钥分为公钥和私钥,这两把密钥可以互为加解密。公钥是公开的,私钥是由个人自己持有,并且必须妥善保管和注意保密。

Linux如何设置ssh密钥(免密码)登录

Linux设置密钥登录的步骤

一、生成密钥(公钥与私钥)

执行ssh-keygen命令,生成id_rsa和id_rsa.pub两个文件,id_rsa是私钥(重要,需安全保管),id_rsa.pub是公钥,密钥生成过程中可根据提示对密钥设置密码,也可留空直接回车。

Linux如何设置ssh密钥(免密码)登录

解释:

  • -t 选项指定要使用的加密算法,“rsa”表示使用RSA算法;
  • -b 选项指定密钥的长度;
  • -C 选项是可选的,用于添加注释。

二、创建authorized_keys文件并设置权限

1.查看密钥认证文件authorized_keys是否存在,若不存在则创建并授权,命令如下:

[root@server1 ~]# touch ~/.ssh/authorized_keys
[root@server1 ~]# ~/.ssh/authorized_keys

2.将公钥内容追加到authorized_keys文件中

[root@server1 ~]# cd ~/.ssh
[root@server1 .ssh]# cat id_rsa.pub >> authorized_keys

三、设置sshd配置文件允许使用密钥登录

修改sshd_config文件,启用以下参数:

RSAAuthentication yes
PubkeyAuthentication yes
PermitRootLogin yes
AuthorizedKeysFile .ssh/authorized_keys

修改完配置文件,重启sshd服务:

[root@server1 ~]# systemctl restart sshd

四、使用私钥登录验证

在Linux主机上登录验证:

[root@server1 .ssh]# ssh root@localhost -i id_rsa
Last login: Wed Sep 13 17:13:28 2023 from 192.168.15.1

在Win下使用ssh客户端导入私钥登录验证

Linux如何设置ssh密钥(免密码)登录

五、禁用密码登录

修改sshd_config文件,启用以下参数:

PasswordAuthentication no

重启sshd服务:

[root@server1 ~]# systemctl restart sshd

至此,Linux已经设置为密钥登录,相对于使用密码认证登录的方式更为安全,前提是私钥要安全保管。今天的分享就到这里了,你学会了吗?

延伸 · 阅读

精彩推荐
  • Linuxfstab文件格式浅析

    fstab文件格式浅析

    在使用quota对磁盘进行限额时,如果你还不了解fstab文件的格式,那么请一定要好好看看这篇文章....

    Linux教程网2722020-04-16
  • LinuxYum安装中出现错误mirrorlist.txt的解决方法

    Yum安装中出现错误mirrorlist.txt的解决方法

    前几天在使用Yum install命令安装软件的时候一直提示一个mirrorlist.txt错误,通过查找相关的资料现在找到了解决的方法,所以这篇文章就整理出来和大家分享...

    Linux教程网12242021-11-17
  • Linux详解Linux文件锁flock

    详解Linux文件锁flock

    这篇文章主要介绍了详解Linux文件锁flock,在多个进程同时操作同一份文件的过程中,很容易导致文件中的数据混乱,需要锁操作来保证数据的完整性,这里...

    鱼翅10139582021-12-10
  • LinuxLinux硬盘问题的八种解决技巧

    Linux硬盘问题的八种解决技巧

    linux硬盘出问题了该怎么办?想知道你为什么总是在屏幕上看到“磁盘已满”的字眼吗?想学习处理这些问题的办法吗?下面分享Linux硬盘问题的八种解决技...

    Linux教程网7032019-10-23
  • LinuxLinux系统下CVS的账号控制操作简介

    Linux系统下CVS的账号控制操作简介

    这篇文章主要介绍了Linux系统下CVS的账号控制操作,与Git一样,CVS也是主流的版本控制系统之一,需要的朋友可以参考下...

    坚持到底3402019-09-02
  • LinuxLinux中进程和线程的对比与区别

    Linux中进程和线程的对比与区别

    这篇文章主要介绍了Linux中进程和线程的对比与区别的相关资料,需要的朋友可以参考下...

    Sweet_wen10632022-02-12
  • Linux600 条最强 Linux 命令总结

    600 条最强 Linux 命令总结

    来源:运维网工 今天为大家带来一篇 Linux 命令总结得非常全面的文章,同时也是平时工作中使用率非常高的操作命令。 1. 基本命令 uname - m 显示机器的处...

    未知1132023-05-08
  • Linux如何在Linux上安装libvirt虚拟化工具

    如何在Linux上安装libvirt虚拟化工具

    libvirt是Linux下的虚拟化工具,那么要怎么安装虚拟化工具libvirt,下面为大家详细介绍下如何在Linux上安装libvirt虚拟化工具,感兴趣的朋友可以参考下 ...

    Linux技术网3912019-10-18