听起来你快到了!我不确定你有什么和没有做什么,所以我会解释整个过程。
首先,我猜测(因为您使用的是 puTTY)您的计算机运行的是 Windows?如果是这样,首先您需要安装适用于 Windows 的 Git,您可以从 official Git website 下载它。下载并安装它,接受安装程序中的默认选项。
这将在您的开始菜单中留下一个名为 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 文件中。如果您只使用一种表示replace将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 用户访问。
你应该会发现你现在可以开始了!