scp免密传输教程

scp免密传输教程

为了在使用 scp 命令时不需要输入密码,通常的做法是通过设置 SSH 公钥认证来实现。这种方法不仅避免了每次都要输入密码的麻烦,而且也更加安全。下面是如何设置 SSH 公钥认证的步骤:

1. 生成 SSH 密钥对(如果你还没有的话)

在你的客户端机器上打开终端,运行以下命令来生成一个 SSH 密钥对。当提示你输入文件保存位置时,可以直接按回车键使用默认位置。

ssh-keygen -t rsa -b 2048

当提示输入密码时,可以选择留空,这样就不需要在使用密钥时输入密码。
注:如果已经存在旧的密钥选择不覆盖,然后拷贝旧的密匙

2. 将公钥复制到服务器

可以手动将公钥内容添加到服务器的 ~/.ssh/authorized_keys 文件中。首先,显示并复制你的公钥内容:

cat ~/.ssh/id_rsa.pub

如果是windows系统则用txt打开复制 ctrl+A复制全部内容。
在这里插入图片描述
然后登录到你的服务器,编辑 ~/.ssh/authorized_keys 文件,并将复制的公钥内容粘贴到文件的末尾。
注:注意不要删除其他人的key!

3. 使用 scp 命令免密码传输文件

设置完毕后,你现在应该可以使用 scpssh 命令免密码登录到服务器了。再次运行你的 scp 命令,不应该再提示你输入密码:

scp -r ./dist/ [email protected]:/usr/share/nginx/html

注意事项

  • 安全性:不使用密码的 SSH 登录更依赖于密钥的安全性,因此请确保你的私钥文件安全,不被未授权的人访问。
  • 权限问题:确保服务器上的目标目录允许你写入。如果遇到权限拒绝的问题,可能需要检查目录的权限设置。

通过以上步骤,你就可以实现无密码使用 scp 来传输文件了,这对于自动化脚本和提高日常工作效率非常有帮助。