配置免密登陆服务器

将你的 SSH 公钥(通常是 id_rsa.pub 文件)复制到远程服务器,以便可以使用 SSH 密钥对进行无密码登录,这是一个常见需求。可以通过多种方式完成,但最简单和推荐的方法是使用 ssh-copy-id 工具。以下是具体步骤:

方法1. 使用 ssh-copy-id (建议)

1.1 确保你已经有 SSH 密钥对:

首先检查你本地的 ~/.ssh/ 目录下是否有 id_rsa 和 id_rsa.pub。你需要将 id_rsa.pub 复制到服务器。

bash 复制代码
   ls ~/.ssh/id_rsa.pub

如果没有,可以通过以下命令生成:

bash 复制代码
   ssh-keygen -t rsa

默认情况下,它会在 ~/.ssh/ 中创建 id_rsa 和 id_rsa.pub。

1.2 使用 ssh-copy-id:

ssh-copy-id 工具可以自动将你的公钥添加到远程主机上的 ~/.ssh/authorized_keys 文件中。

运行以下命令:

bash 复制代码
   ssh-copy-id user@remote-server

user 是你要登录的远程服务器的用户名。

remote-server 是远程服务器的 IP 地址或主机名。

这将提示你输入远程服务器密码来完成初次验证,随后它会自动复制并配置公钥。

方法2. 手动复制公钥

如果 ssh-copy-id 不可用,可以手动复制公钥:

  1. 手动复制公钥内容:
    打开 id_rsa.pub,然后复制内容:
bash 复制代码
   cat ~/.ssh/id_rsa.pub
  1. SSH 连接到远程服务器:
    使用启用了密码登录的 SSH 客户端连接到服务器:
bash 复制代码
   ssh user@remote-server
  1. 在服务器上配置公钥:
    在连接的服务器上,将公钥粘贴到 ~/.ssh/authorized_keys 文件中:
bash 复制代码
   mkdir -p ~/.ssh
   echo "your-public-key-content" >> ~/.ssh/authorized_keys
   chmod 700 ~/.ssh
   chmod 600 ~/.ssh/authorized_keys

确保以后你的 authorized_keys 文件和父目录 .ssh 具有正确的权限(通常为 700 和 600),否则 SSH 可能拒绝使用公钥登录。

通过上述方法,你应该能够成功地将公钥复制到远程服务器,从而实现无密码 SSH 登录。

相关推荐
松涛和鸣1 小时前
49、智能电源箱项目技术栈解析
服务器·c语言·开发语言·http·html·php
凉、介1 小时前
SylixOS 中的 Unix Socket
服务器·c语言·笔记·学习·嵌入式·sylixos
RisunJan1 小时前
Linux命令-ipcs命令(报告进程间通信(IPC)设施状态的实用工具)
linux·运维·服务器
HABuo2 小时前
【Linux进程(四)】进程切换&环境变量深入剖析
linux·运维·服务器·c语言·c++·ubuntu·centos
橘颂TA3 小时前
【Linux】死锁四条件的底层逻辑:从锁冲突到 STL 组件的线程安全实践(Ⅵ)
linux·运维·服务器·c++·死锁
黄焖鸡能干四碗3 小时前
智能制造工业大数据应用及探索方案(PPT文件)
大数据·运维·人工智能·制造·需求分析
橙露3 小时前
国产PLC与进口PLC全面对比分析:技术、市场与未来趋势
运维·网络
lbb 小魔仙3 小时前
【Linux】云原生运维效率提升:Linux 终端工具链(kubectl + tmux + fzf)组合拳教程
linux·运维·云原生
清水白石0083 小时前
解构异步编程的两种哲学:从 asyncio 到 Trio,理解 Nursery 的魔力
运维·服务器·数据库·python