听起来你快到了!我不确定你有什么和没有做过什么,所以我会解释整个过程。
首先,我猜(因为您使用的是 puTTY)您的计算机运行 Windows?如果是这样,首先您需要安装适用于 Windows 的 Git,您可以从Git 官方网站下载它。下载并安装它,接受安装程序中的默认选项。
这将在您的开始菜单中留下一个名为Git Bash的项目。您将使用它来执行接下来的操作。(您实际上并不需要安装 Git 本身,但适用于 Windows 的 Git 安装程序添加了一些ssh-keygen
您需要的额外工具。)
如果您的计算机实际上运行的是 Linux 或 Mac OS X 而不是 Windows,那么您已经拥有所需的工具。您可以按照相同的说明进行操作,但不要使用 Git Bash 输入命令,而是使用终端窗口。
从现在开始,我将只提及“在终端中”键入内容。如果您使用的是 Windows,请在 Git Bash 窗口中键入这些内容。
第 1 步:在您自己的计算机上,检查 SSH 密钥对
在终端中,键入:
ls ~/.ssh/id_rsa*
这应该列出两个文件:id_rsa 和 id_rsa.pub。如果存在,请继续执行步骤 2。如果不存在,请键入:
ssh-keygen
然后按照提示创建它们。然后再次运行该ls
命令以确认它们现在在那里。
第 2 步:将您的公共 SSH 密钥上传到服务器
公钥是名为 id_rsa.pub 的那个。scp
您可以使用以下命令将其上传到服务器:
scp ~/.ssh/id_rsa.pub git@my-server.com
出现提示时输入 git 用户的密码。
第 3 步:将您的密钥添加到 git 用户的 authorized_keys 文件中
首先以 git 用户身份 SSH 到服务器:
ssh git@my-server.com
再次输入 git 用户的密码。以 git 用户身份登录后,键入以下内容:
mkdir -p ~/.ssh/
如果 .ssh 目录尚不存在,这将创建它。如果它确实存在,它不会做任何事情。
现在将您的密钥添加到 authorized_keys 文件中:
cat ~/id_rsa.pub >> ~/.ssh/authorized_keys
这将获取您刚刚上传的文件 id_rsa.pub 的内容,并将它们添加到 authorized_keys 文件的末尾。如果 authorized_keys 不存在,此命令将首先创建它。
>>
(注意:在该命令行中键入两个右尖括号 ( ) 时要非常小心。两个右尖括号表示将 id_rsa.pub 的内容附加到 authorized_keys 文件中。如果只使用一个,则表示将authorized_keys 的内容替换为id_rsa.pub 的内容,你不想这样做。)
cat
您可以通过在每个文件上运行并确保您可以在 authorized_keys 末尾看到 id_rsa.pub 的内容来检查这是否有效:
cat ~/id_rsa.pub
cat ~/.ssh/authorized_keys
确认后,删除 id_rsa.pub;你不会再需要它了。
rm ~/.ssh/id_rsa.pub
最后,设置 .ssh 目录和 .ssh/authorized_keys 的权限,以便只有这些文件的所有者(git 用户)可以访问它们。否则,SSH 服务器将拒绝使用它们。所以:
chmod 700 ~/.ssh
chmod 400 ~/.ssh/authorized_keys
这使得该目录只能由 git 用户使用,并且其中的文件只能由 git 用户访问。
您应该会发现您现在可以开始了!