Linux ssh 免密失效

sudo chmod -R 777 /home/xxx
sudo chown -R xxx:xxx  /home/xxx
为什么我输入这两条指令后,ssh免密失效了?

当你使用 sudo chmod -R 777 /home/xxxsudo chown -R xxx:xxx /home/xxx 这两条指令后,可能会导致 SSH 免密登录失效的原因有以下几个方面:

  1. 权限问题
       - chmod -R 777 /home/xxx/home/xxx 目录及其所有子目录和文件的权限设置为rwxrwxrwx(777),这意味着任何人都可以读取、写入和执行这些文件。这可能会导致 SSH 密钥文件的权限过于宽松,SSH 服务出于安全考虑会拒绝使用这些密钥。

  2. 所有权问题
       - chown -R xxx:xxx /home/xxx/home/xxx 目录及其所有子目录和文件的所有权更改为了 xxx 用户和 xxx 组。如果之前 SSH 密钥文件的所有权不是 xxx,那么更改所有权可能会影响 SSH 服务的正常使用。

  3. SSH 密钥文件权限
       - SSH 密钥文件(如 ~/.ssh/id_rsa~/.ssh/authorized_keys)通常需要特定的权限设置。例如,~/.ssh 目录通常需要权限 700,而 ~/.ssh/authorized_keys 文件通常需要权限 600。如果你将这些文件的权限设置为 777,SSH 服务可能会拒绝使用它们。

解决方法

  1. 恢复适当的权限
       - 确保 ~/.ssh 目录的权限为 700~/.ssh/authorized_keys 文件的权限为 600
       bash    sudo chmod 700 /home/xxx/.ssh    sudo chmod 600 /home/xxx/.ssh/authorized_keys    

  2. 检查所有权
       - 确保 ~/.ssh 目录和文件的所有权属于 xxx 用户和 xxx 组。
       bash    sudo chown -R xxx:xxx /home/xxx/.ssh    

  3. 验证 SSH 配置
       - 确保 SSH 配置文件 /etc/ssh/sshd_config 中的设置没有被更改,特别是与密钥认证相关的设置。

  4. 重启 SSH 服务
       - 重启 SSH 服务以应用更改。
       bash    sudo systemctl restart sshd    

通过以上步骤,你应该能够恢复 SSH 免密登录功能。如果问题仍然存在,请检查 SSH 服务日志(通常在 /var/log/auth.log/var/log/secure)以获取更多信息。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

飘飘然雪

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值