MacOS Sonoma14.2.1系统SSH免密登录

简介: 【7月更文挑战第9天】在MacOS Sonoma 14.2.1中设置SSH免密登录,包括:1) 使用`ssh-keygen`生成RSA密钥对;2) 使用`ssh-copy-id`将公钥传到远程主机;3) 用`ssh-add --apple-use-keychain`添加私钥到ssh-agent,并为重启后自动添加配置自动化脚本;4) 可选地,编辑`~/.ssh/config`设置别名简化登录。确保远程主机的`.ssh/authorized_keys`文件权限为600。

在 MacOS Sonoma14.2.1系统中实现SSH免密登录,可按照以下步骤进行操作:


  1. 生成SSH密钥对
    打开终端,进入到~/.ssh目录(若该目录不存在,可以手动创建)。然后执行以下命令生成密钥对:
    ssh-keygen -t rsa -f cvm
    执行命令后,连续两次直接回车,将在~/.ssh目录下生成对应的密钥对,即私钥cvm和公钥cvm.pub
  2. 将公钥上传至远程主机
    使用以下命令将公钥上传到要免密登录的远程主机(需替换其中的root为远程主机的用户名,ip为远程主机的IP地址):
    ssh-copy-id -i ~/.ssh/cvm.pub root@ip
    执行该命令期间,可能需要输入一次远程主机的密码。
  3. 将私钥添加到ssh-agent高速缓存
    在Mac系统中,需要使用“ssh-add”命令将私钥添加至ssh-agent高速缓存。但由于“-k”参数对于Mac来说已经过期,需将其换成“–apple-use-keychain”。具体命令如下(需替换~/.ssh/id_liupp为你的私钥路径):
    ssh-add --apple-use-keychain ~/.ssh/cvm
  4. 实现SSH免密登录
    添加成功后,在终端执行以下命令即可实现免密登录远程主机:
    ssh root@ip
  5. 解决重启后免密登录失效的问题ssh-add将私钥添加到高速缓存,但缓存在重启后会失效,需要每次重启后重新添加。在Mac下可通过以下操作解决:
  1. 在“应用程序”中找到“自动操作”应用(或通过ctrl+space搜索),打开后点击“取消”,再点击启动栏的自动操作图标,在“选取文稿类型”中选择“应用程序”。
  2. 左侧“资源库”选择“实用工具”,双击右侧的“运行shell脚本”,将ssh-add --apple-use-keychain ~/.ssh/cvm命令复制到运行脚本中,点击标题栏左侧的“未命名”,给该自动执行程序命名(例如“add-ssh-key”)并保存至指定位置。
  3. 打开“系统设置”,左侧搜索栏搜索“登录项”,在“登录时打开”中将保存的自动执行程序(add-ssh-key)添加进来。


经过以上设置,重启后即可实现免密登录。


此外,若要通过别名实现免密登录,可回到Mac的~/.ssh目录(若没有config文件可手动创建),添加以下内容:


host cvm
   hostname ip
   user root
   identityfile ~/.ssh/cvm


其中,host后的cvm为别名,可自定义;hostname为远程主机的IP地址;user为用户名;identityfile为私钥的路径。之后就可以直接使用ssh cvm进行免密登录了。


需注意,SSH进行认证的过程中除了对用户目录有权限要求外,对服务器上的.ssh文件夹和authorized_keys文件同样有要求。如果日志中提示这两个的问题,可以通过如下方式进行修改:


chmod 700 ~/.ssh
   chmod 600 ~/.ssh/authorized_keys


同时,免密登录的处理是用户对用户的,切换其他用户后,仍然需要输入密码。另外,远程机器的.ssh目录需要700权限,authorized_keys文件需要600权限,否则配置可能不成功(导致每次登录都得重新输入密码)。

相关文章
|
15天前
|
JavaScript 应用服务中间件 Linux
【应用服务 App Service】解决无法从Azure门户SSH登录问题
【应用服务 App Service】解决无法从Azure门户SSH登录问题
|
16天前
|
机器学习/深度学习 存储 Linux
【机器学习 Azure Machine Learning】使用VS Code登录到Linux VM上 (Remote-SSH), 及可直接通过VS Code编辑VM中的文件
【机器学习 Azure Machine Learning】使用VS Code登录到Linux VM上 (Remote-SSH), 及可直接通过VS Code编辑VM中的文件
|
15天前
|
安全 Shell Linux
如何禁止某个用户使用ssh登录
本文介绍了五种禁止用户通过SSH登录的方法:1) 修改`/etc/ssh/sshd_config`文件中的`DenyUsers`和`DenyGroups`来阻止特定用户或用户组登录;2) 将用户的默认shell设置为`/usr/sbin/nologin`或`/bin/false`以禁用其SSH访问;3) 利用PAM(可插入认证模块)通过编辑`/etc/security/sshd.conf`来限制登录权限;4) 通过编辑`/etc/hosts.deny`文件拒绝特定用户的SSH访问;5) 锁定或禁用用户账号以阻止所有类型的登录。每种方法都提供了详细的步骤指导。
36 1
|
23天前
|
存储 安全 测试技术
【超实用却暗藏杀机】sshpass:一键免密SSH登录的神器,为何生产环境却要敬而远之?探秘背后的安全隐患与替代方案!
【8月更文挑战第16天】sshpass 是一款便捷工具,可实现自动化SSH登录,简化脚本中的远程连接流程。通过后台自动处理密码输入,便于执行远程操作,如 `sshpass -p 'yourpassword' ssh user@remotehost`。也可结合更多SSH选项使用,例如指定私钥文件。然而,因需明文传递密码,存在较大安全隐患,不适于生产环境;推荐使用公钥认证以增强安全性。
28 4
|
18天前
|
安全 Linux Shell
Linux系统之间实现免密码登录(SSH无密码登录
【8月更文挑战第21天】要在Linux系统间实现SSH免密码登录,需先在源机器生成SSH密钥对,然后将公钥复制到目标机器的`.ssh/authorized_keys`文件中。可通过`ssh-keygen`命令生成密钥,并使用`ssh-copy-id`命令传输公钥。最后测试SSH连接,确保能无密码登录。若目标机器缺少相关目录或文件,需手动创建并设置适当权限。完成这些步骤后,即可实现安全便捷的免密码登录。
40 0
|
18天前
|
Ubuntu Linux 网络安全
在Linux中,如何禁用root用户直接SSH登录?
在Linux中,如何禁用root用户直接SSH登录?
|
2月前
|
安全 Linux 网络安全
|
21天前
|
存储 安全 Linux
说到Linux安全,SSH限制IP登录绕不开这3种方法!
说到Linux安全,SSH限制IP登录绕不开这3种方法!
|
26天前
|
Linux 网络安全 数据安全/隐私保护
Linux——配置SSH免密登录
Linux——配置SSH免密登录
26 0
|
1月前
|
Linux 网络安全 数据安全/隐私保护
配置ssh免密登录
配置ssh免密登录