Gig2go:解压缩已发送的packfile失败

时间:2015-07-29 17:33:21

标签: git go libgit2

我为此苦苦挣扎。我正在尝试使用以下代码将更改推送到repo:

// Get remote
remote, err := repo.Remotes.Lookup("origin")
if err != nil {
    remote, err = repo.Remotes.Create("origin", repo.Path())
    if err != nil {
        return err
    }
}

// Get the branch
branch, err := repo.Branch()
if err != nil {
    return err
}

// Get the name
branchName, err := branch.Name()
if err != nil {
    return err
}

if err := remote.Push([]string{"refs/heads/"+branchName}, &git.PushOptions{}); err != nil {
    return err
}

一切似乎都很好,但我一直收到这个错误:

unpacking the sent packfile failed on the remote

在阅读了几个git资源后,我现在明白错误的含义,但我仍然不知道是什么导致它。

修改

我刚刚根据@Carlos的建议尝试使用Git,现在我正在获取更多信息:

git push --set-upstream origin master
Counting objects: 3, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 241 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
remote: error: insufficient permission for adding an object to repository database ./objects
remote: fatal: failed to write object
error: unpack failed: unpack-objects abnormal exit
To http://xxxxxxx/xxxxxx/app.git
 ! [remote rejected] master -> master (unpacker error)
error: failed to push some refs to 'http://xxxxxxx/xxxxxxx/app.git'

我认为我获得了权限,这是我的Git目录在服务器上的样子:

root@CodeSpaces-001:/home/git# ll
total 40
drwxr-xr-x 5 git  git  4096 Jul 29 19:22 ./
drwxr-xr-x 3 root root 4096 Jul 29 18:21 ../
drwxrwxr-x 3 git  git  4096 Jul 29 19:22 apps/ # My repos are in here

这还不够吗?

2 个答案:

答案 0 :(得分:1)

这是一个错误,发生在服务器上,所以要查看的地方就是它的日志。你试过用git做同样的操作吗?我不记得副手,但可能有一个额外的错误字符串,libgit2目前没有返回。

在服务器上解压缩的错误通常与git在遥控器上运行的用户的权限有关。

答案 1 :(得分:0)

我在VSTS Sync期间遇到了同样的问题,并在VSTS输出窗口中看到了相同的错误消息。

我的解决方法是转到https://app.vssps.visualstudio.com/_signedin,然后很可能将我的信用记录到远程服务器上。

之后,再次回到VSTS并同步,错误消失了。 HIH。