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权限,否则配置可能不成功(导致每次登录都得重新输入密码)。

相关文章
|
2月前
|
安全 网络安全 数据安全/隐私保护
Debian 12系统中允许Root远程SSH登录解决方法!
在 Debian 12 系统中开启 SSH 远程 Root 登录需修改 SSH 配置文件 (`sshd_config`),将 `PermitRootLogin` 设置为 `yes` 并确保密码认证启用。完成后重启 SSH 服务并验证连接。若防火墙启用,需放行端口 22。注意,直接开放 Root 登录可能带来安全风险,建议使用普通用户登录后切换至 Root。
175 1
|
5月前
|
监控 Ubuntu 安全
debian或Ubuntu中开启ssh允许root远程ssh登录的方法
在Debian或Ubuntu系统中启用root用户的SSH远程登录需要编辑SSH配置文件、设置root密码并重启SSH服务。虽然这可以在某些情况下提供便利,但必须注意安全性,通过使用强密码、限制IP访问、使用SSH密钥认证等方法来保护服务器的安全。
2278 5
|
9月前
|
JavaScript 应用服务中间件 Linux
【应用服务 App Service】解决无法从Azure门户SSH登录问题
【应用服务 App Service】解决无法从Azure门户SSH登录问题
108 0
|
7月前
|
XML 大数据 网络安全
大数据-03-Hadoop集群 免密登录 超详细 3节点云 分发脚本 踩坑笔记 SSH免密 集群搭建(一)
大数据-03-Hadoop集群 免密登录 超详细 3节点云 分发脚本 踩坑笔记 SSH免密 集群搭建(一)
156 5
|
7月前
|
大数据 网络安全 数据安全/隐私保护
大数据-03-Hadoop集群 免密登录 超详细 3节点云 分发脚本 踩坑笔记 SSH免密 集群搭建(二)
大数据-03-Hadoop集群 免密登录 超详细 3节点云 分发脚本 踩坑笔记 SSH免密 集群搭建(二)
265 5
|
9月前
|
机器学习/深度学习 存储 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中的文件
107 4
|
9月前
|
安全 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) 锁定或禁用用户账号以阻止所有类型的登录。每种方法都提供了详细的步骤指导。
1157 2
|
9月前
|
安全 Linux Shell
Linux系统之间实现免密码登录(SSH无密码登录
【8月更文挑战第21天】要在Linux系统间实现SSH免密码登录,需先在源机器生成SSH密钥对,然后将公钥复制到目标机器的`.ssh/authorized_keys`文件中。可通过`ssh-keygen`命令生成密钥,并使用`ssh-copy-id`命令传输公钥。最后测试SSH连接,确保能无密码登录。若目标机器缺少相关目录或文件,需手动创建并设置适当权限。完成这些步骤后,即可实现安全便捷的免密码登录。
369 0
|
网络安全 数据安全/隐私保护
item2实现ssh的免密登录
编写expect脚本 1 新建脚本(脚本位置没有明确要求) touch ssh-info.sh 2 脚本内容 #!/usr/bin/expect set timeout 30 spawn ssh -p [lindex $argv 0] [lind...
1299 0
|
1月前
|
安全 Linux 网络安全
在Linux(CentOS和AWS)上安装更新的git2的方法并配置github-ssh
经过以上这些步骤,你现在就能在GitHub上顺利往返,如同海洋中的航海者自由驰骋。欢迎你加入码农的世界,享受这编程的乐趣吧!
78 10