3

概括

出于某种原因,当我以 root 身份登录时,git 命令的工作方式不同。例如,当我以普通用户身份登录时,我可以克隆一个存储库,但我不能将同一个存储库克隆到与 root 相同的目录中。

例子

普通用户:

> git clone git@192.168.1.103:testing
Cloning into 'testing'...
Enter passphrase for key '/home/Matthew/.ssh/id_rsa': 
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 6 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (6/6), done.

(然后我 su 到 root 并删除 repo ...)

根:

# git clone git@192.168.1.103:testing
Cloning into 'testing'...
Password:
Password:
Password:
Permission denied (publickey,keyboard-interactive).
fatal: The remote end hung up unexpectedly

我的故障排除尝试

起初我认为这是与 ssh 相关的某种问题,但从各种可能的方式进行 ssh-ing 似乎都可以正常工作。(我没有更改设置以使您能够通过 ssh 直接以 root 身份登录。)

设置详情

  • 我已经为 root 和其他用户生成了 ssh 密钥。
  • 我试图将 repos 克隆到的机器正在运行 FreeBSD 9(我刚刚安装了它——试图了解 *nix、托管、系统管理员等)
  • git server 是 mac 上的 gitolite(我已经使用了一段时间没有问题)

结论

我有一种感觉,这对于拥有更多 *nix/git 印章的人来说是显而易见的,但到目前为止我还没有弄清楚/在互联网上找到答案。谢谢你的帮助!

4

1 回答 1

5

问题

请注意,系统不会提示您的普通用户输入密码,但会提示您的超级用户。这是根的私钥没有加载到可访问的 ssh 代理中的一个重要线索。

解决方案

在你 su 到 root 之后,你需要启动你的 ssh-agent 并加载你的密钥。例如:

sudo su - root
eval `ssh-agent`
ssh-add

如果您的密钥在您的代理中可见,ssh-add -l那么您此时应该能够成功克隆。

注意事项

由于您在服务器上使用 gitolite,因此您不能使用密码认证——您必须使用公钥认证。为了完成这项工作,您还需要确保已将 root 的公钥添加到 gitolite 配置中,并授权 root 用户访问您希望该帐户访问的任何存储库。

于 2012-06-16T07:07:31.227 回答