33

我搜索了一段时间,但找不到解决问题的方法。

git我有一个服务器,我可以使用用户名和本地 git 存储库通过 ssh 连接。
现在我想将我的本地存储库推送到服务器上新创建的存储库。

这是我所做的:

  • 在中创建了一个 git 存储库/home/git/test.git
  • 将存储库初始化为裸
  • 在本地机器上添加远程存储库
    git remote add test ssh://git@serverIp:/home/git/test.git
  • 现在我执行了推送命令:
    git push test master

我总是得到

fatal: could not read from remote repository

Please make sure you have the correct access rights
and the repository exists.

我正在使用本地 Windows 7 机器并想上传到 linux 服务器。
我可以使用用户通过 ssh 登录git。我还尝试以root用户身份执行此操作(以使事情工作一次),结果相同。
我从来没有被要求提供 ssh password

我真的不知道我做错了什么。
在你称之为重复之前,我搜索了很多这个问题,但似乎没有人谈论同样的问题。

更新:

  • “哪个 git”返回 /usr/bin/git
  • PATH 回显包括 /usr/bin
  • id_rsa 和 id_rsa.pub 文件均已设置并输入密码
  • ssh git@serverIp which git-receive-pack 也可以工作并返回 /usr/bin/git-receive-pack
  • ssh git@serverIp ls /home/git/test.git 有效
  • 所有相关目录都是 chmod 755
  • git 是存储库的所有者
  • auth.log 文件在尝试推送命令时没有新条目
  • GIT_TRACE=2 git push test master 返回:

    'C:\Program Files (x86)\PuTTY\plink.exe' '-batch' 'git@serverIp' 'git-receive-pack '\''/home/git/test.git'\''' 致命:无法从远程存储库中读取。请确保您具有正确的访问权限并且存储库存在。

4

4 回答 4

17

在这种情况下,使用 openssh 而不是 putty 是关键。


原始答案(调试提示)

我可以使用用户通过 ssh 登录git

这意味着这有效:

ssh git@serverIp

您确实HOME定义了一个变量,并且 ssh 公钥/私钥 ( id_rsa/ id_rsa.pub) 在%HOME%/.ssh/.

这个问题提出了一个不同的网址:

git remote set-url test git@serverIp:/home/git/test.git

确保您确实将您的 git 存储库创建为 git(而不是作为 root,当您创建 git 帐户时,如本问题所示)。
ssh git@serverIp "which git"应该返回 git 可执行文件的路径。

还要检查所有父目录是否为用户或组x设置了相关(执行)位,运行。 此外,可以通过以下方式获取 git 命令的更多信息:gitgitgroupls -ld /home /home/git /home/git/test.git

  • git push --verbose
    或者:
  • GIT_TRACE=2 git push test master

如果您有带密码的 ssh 私钥,最好先使用未受密码保护的 ssh 私钥测试这些 ssh 命令,看看问题是否仍然存在。
或者,您可以保留受密码保护的 ssh 密钥,但在此答案中仔细检查您的.bashrc密钥。


对于任何 ssh 连接问题(需要 git 的密码),请检查:


在您的情况下,由于它适用于ssh git@serverIp(交互式安全外壳),但不适用于 git(打开一个非交互式安全外壳),请查看此线程,它引用了这个

当使用命令行启动 ssh 时,会启动一个非交互式非登录 shell。
但是...在这种情况下bash不使用$BASH_ENV,因此将其设置为~/.ssh/environment(例如 to /etc/profile)无济于事。
bash 所做的是 source/etc/bashrc~/.bashrc.

确保/etc/profile确实定义了 的路径git,因为可以在此处使用非登录帐户(此处似乎就是这种情况,因为ssh git@serverIp "which git"有效,而且ssh git@serverIp "git --version"应该也是如此)。

但也要检查正确的问题,并chmod 755/home,/home/git和上测试 a /home/git/test.git

于 2013-04-20T10:47:13.360 回答
8

您还可以通过以下方式检查您的 SSH 身份:

$ ssh-add -L

我有一个类似的问题。我的身份中有一个错误的密钥,不记得为什么。我只是删除了我所有的身份(也许您需要再次添加密钥):

$ ssh-add -D  

然后我没有问题地推/拉。

于 2014-07-13T15:33:48.240 回答
7

我个人对此有两个不同的问题:

  1. plink(在 Windows 上由 git 使用)不接受id_rsa私钥,因为它是 OpenSSH 2 格式 => 我必须将它(使用puttygen)转换为 PuTTY 自己的.ppk格式并通过 Git 扩展“ Remotes”对话框附加

  2. 我错误地指定了 git 文件夹的路径,因为我的 ssh 会话被 chroot(这可能是错误的词)并且我将我的 FTP“ root”指定为“ /”,而它是“ /home/www/username/”。

我理解了这一切,GIT TRACE=2如上所述使用,也通过使用procmon来确定确切的命令行plink,然后使用它,添加“ -v”选项(“详细”)。

于 2014-01-29T10:58:48.380 回答
0

将 GIT_SSH 环境变量设置为TortoisePlink.exe(您可能需要为此下载 TortoiseGit)的完整路径,而不是 PuTTY 的plink.exe. 这将允许弹出对话框窗口提示一些事情,即确认指纹或输入密码。如果plink.exe通过 Git 使用,则无法对 plink.exe 提示输入响应,如果有任何提示将导致您看到的致命错误。

于 2015-11-04T20:31:52.263 回答