gpt4 book ai didi

git push --atomic - 没有失败

转载 作者:太空狗 更新时间:2023-10-29 14:36:54 25 4
gpt4 key购买 nike

我一直在尝试为 git push 使用相对较新的 --atomic 选项,但它对我不起作用,即,它仍然允许一些 refs 改变即使其他人失败了。

从diff来看似乎here远程服务器上也需要有一些东西可以接受原子标志。虽然这是有道理的,但似乎默认是使用它。

我正在使用 http 协议(protocol)推送到 BitBucket 服务器实例。服务器上当前的 Git 版本是“git version 2.8.1”。

我需要在服务器上配置什么才能让它工作吗?

编辑:

下面是一个可以重现的例子。

服务器上的配置:

$ git --version
git version 2.8.1

$ git config --get-all --show-origin receive.advertiseatomic
file:/home/bitbucket/.gitconfig 1

在客户端:

$ git --version
git version 2.8.2.windows.1

$ git push <local-path>/.git HEAD:refs/heads/wwww HEAD:refs/heads/zzz --force-with-lease=zzz --atomic
error: atomic push failed for ref refs/heads/zzz. status: 7

fatal: The remote end hung up unexpectedly
To <local-path>/.git
! [rejected] HEAD -> wwww (atomic push failed)
! [rejected] HEAD -> zzz (stale info)
error: failed to push some refs to '<local-path>/.git'

$ git push origin HEAD:refs/heads/wwww HEAD:refs/heads/zzz --force-with-lease=zzz --atomic
Total 0 (delta 0), reused 0 (delta 0)
remote:
remote:
To http://me@bitbucket-local.com/scm/proj/repo.git
* [new branch] HEAD -> wwww
! [rejected] HEAD -> zzz (stale info)
error: failed to push some refs to 'http://me@bitbucket-local.com/scm/proj/repo.git'

最佳答案

我是 Bitbucket Server 开发人员之一。很抱歉这么晚才回答这个问题,但我只是注意到了。

这似乎就是 Git 的工作方式。例如,如果您通过 HTTPS 使用 GitHub 重新测试 git push --atomic,您将看到相同的行为。

查看Git源码,remote-curl.c,为git-remote-http提供了main git-remote-https,调用git send-pack 发送打包文件时,不传递--atomic。 ( See how the send-pack command line is constructed here ) 因此,当使用 git push --atomic 和 HTTP(S) 远程时,--atomic 会被忽略,推送会正常运行。这就是您看到正在创建分支的原因。

请注意,这根本不是服务器端行为。在这种情况下,Bitbucket Server 或任何其他托管服务提供商都无能为力。如果您使用 GIT_TRACE_PACKET=1 来跟踪客户端和服务器相互发送的内容,您将看到如下对话:

22:16:06.562939 pkt-line.c:46           packet:          git< #
service=git-receive-pack
22:16:06.562990 pkt-line.c:46 packet: git< 0000
22:16:06.562994 pkt-line.c:46 packet: git<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319
refs/heads/branch-1\0report-status delete-refs side-band-64k quiet
atomic ofs-delta agent=git/github-g4f6c801f9475
22:16:06.563013 pkt-line.c:46 packet: git<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319 refs/heads/branch-2
22:16:06.563016 pkt-line.c:46 packet: git<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319 refs/heads/branch-3
22:16:06.563019 pkt-line.c:46 packet: git<
fe86a3eae65e18787040499c17a567096159b9ce refs/heads/master
22:16:06.563024 pkt-line.c:46 packet: git< 0000
22:16:06.563329 pkt-line.c:46 packet: git>
HEAD:refs/heads/branch-4
22:16:06.563346 pkt-line.c:46 packet: git> 0000
22:16:06.563357 run-command.c:347 trace: run_command:
'send-pack' '--stateless-rpc' '--helper-status' '--thin' '--progress'
'https://github.com/bturner/atomic-pushes.git/' '--stdin'
22:16:06.563765 exec_cmd.c:129 trace: exec: 'git' 'send-pack'
'--stateless-rpc' '--helper-status' '--thin' '--progress'
'https://github.com/bturner/atomic-pushes.git/' '--stdin'
22:16:06.564691 git.c:348 trace: built-in: git
'send-pack' '--stateless-rpc' '--helper-status' '--thin' '--progress'
'https://github.com/bturner/atomic-pushes.git/' '--stdin'
22:16:06.564788 pkt-line.c:46 packet: git<
HEAD:refs/heads/branch-4
22:16:06.564793 pkt-line.c:46 packet: git< 0000
22:16:06.564797 pkt-line.c:46 packet: git<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319
refs/heads/branch-1\0report-status delete-refs side-band-64k quiet
atomic ofs-delta agent=git/github-g4f6c801f9475
22:16:06.564805 pkt-line.c:46 packet: git<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319 refs/heads/branch-2
22:16:06.564826 pkt-line.c:46 packet: git<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319 refs/heads/branch-3
22:16:06.564830 pkt-line.c:46 packet: git<
fe86a3eae65e18787040499c17a567096159b9ce refs/heads/master
22:16:06.564834 pkt-line.c:46 packet: git< 0000
22:16:06.564970 pkt-line.c:46 packet: git>
0000000000000000000000000000000000000000
6925c65344e87c65e5cd2b56d392cd06ef96ca71 refs/heads/branch-4\0
report-status side-band-64k agent=git/2.4.0
22:16:06.564989 pkt-line.c:46 packet: git> 0000
22:16:06.565027 pkt-line.c:46 packet: git<
00960000000000000000000000000000000000000000
6925c65344e87c65e5cd2b56d392cd06ef96ca71 refs/heads/branch-4\0
report-status side-band-64k agent=git/2.4.00000

在这个输出中,我运行了 git push --atomic https://github.com/... non-fast-forward:refs/heads/master non-fast-forward:refs/heads/分支-4。请注意,当 git send-pack 运行时,没有设置 --atomic 选项(但是 git send-pack does support it being set )。这意味着 atomic handling in send-pack.c永远不会被触发。

您可以从接下来的“对话”中看到这一点。 “git<”行是服务器 对客户端所说的内容,因此您可以看到发送了 ref 广告。 “git>”行是客户端 对服务器说的。请注意,有一个“git>”行发送“refs/heads/branch-4”,但没有类似的行发送“refs/heads/master”。 客户端 甚至根本不会尝试将“主”更新发送到服务器,因为使用服务器的 ref 广告,它已经知道更新不是快速的-转发,并且由于未使用 --force,该更新将失败。

SSH 的有线协议(protocol)输出更简单:

22:56:08.609608 pkt-line.c:46           packet:         push<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319
refs/heads/branch-1\0report-status delete-refs side-band-64k quiet
atomic ofs-delta agent=git/github-g4f6c801f9475
22:56:08.609774 pkt-line.c:46 packet: push<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319 refs/heads/branch-2
22:56:08.609798 pkt-line.c:46 packet: push<
1b9c21b7aeb6ad03957cc8a023b2406d3ccee319 refs/heads/branch-3
22:56:08.609801 pkt-line.c:46 packet: push<
6925c65344e87c65e5cd2b56d392cd06ef96ca71 refs/heads/branch-4
22:56:08.609825 pkt-line.c:46 packet: push<
fe86a3eae65e18787040499c17a567096159b9ce refs/heads/master
22:56:08.609831 pkt-line.c:46 packet: push< 0000

与 HTTPS 类似,“push<”行是服务器对客户端说的。如您所见,服务器发送一个 ref 通告,然后客户端简单地中止——它永远不会向服务器写入一个数据包。

所以在这两种情况下,--atomic 都没有被服务器处理过。这并不是说它永远不会可以,但是对于这些简单的示例,客户端 可以检测到至少一个更新肯定会失败,--atomic 完全在本地处理(或不处理)。

关于git push --atomic - 没有失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37531663/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com