使用git svn完成svn提交历史记录

问题描述 投票:0回答:1

我们正在将一个svn分支迁移到git。

我们无法从git repo中的svn获取完整的提交历史记录,并且需要帮助才能正确获取完整的历史记录。

git svn clone对我们没用,因为它一直没能用

“警告:有太多无法到达的松散物体;运行'git prune'将其移除。”

我们的回购约有r250000提交

我们在https://abc.xyz.com/svn/app1有一个repo根URL

我们有分支A包含文件夹(url:https://abc.xyz.com/svn/app1/proj1/A/trunk

TP

SRC

JRP

我们创建了分支B(来自分支A在r12000)包含文件夹(url:https://abc.xyz.com/svn/app1/path/to/proj2/B/trunk

TP

SRC

JRP

我们想将svn分支B迁移到git作为git中的主干

我们使用非标准的SVN布局

我们使用git-svn版本2.18.0(svn 1.7.14)

我们不使用svn2git

我们做错了什么?

第一个符文

我们尝试了

cd svngitTrunkrepo
git config gc.pruneExpire now
git config gc.auto 1
git svn init  https://abc.xyz.com/svn/app1 -T path/to/proj2/B/trunk --prefix svn/ svngitTrunkrepo
git svn fetch

error: invalid object 100644 xxxyyyzzz111222333444555666 for 'src/to/file.java'
fatal: git-write-tree: error building trees
write-tree: command returned error: 128

第二轮

我们尝试了

cd svngitTrunkrepo2
git config gc.pruneExpire now
git config gc.worktreePruneExpire now
git config gc.reflogExpire now
git config gc.reflogExpireUnreachable now
git config gc.auto 1
git svn init https://abc.xyz.com/svn/app1 -T path/to/proj2/B/trunk --prefix svn/ svngitTrunkrepo2
git svn fetch -r 1:50000
git gc --aggressive
git svn fetch -r 50000:66813
git gc --aggressive
git svn fetch -r 66813:76813
git gc --aggressive
(continue)
git svn fetch -r 216813:220000
git gc --aggressive

运行的输出显示

(continue)
r218237 = b9e6e8ee272fdaa2611f6c3e9ccc05d412ecdf48 (refs/remotes/svn/trunk@218238)
Auto packing the repository in background for optimum performance.
See "git help gc" for manual housekeeping.
Found branch parent: (refs/remotes/svn/trunk) b9e6e8ee272fdaa2611f6c3e9ccc05d412ecdf48
Following parent with do_switch
Successfully followed parent
r218239 = d4af17ac206cb4650f1aa0490dfdb4e1c00a5c16 (refs/remotes/svn/trunk)
Auto packing the repository in background for optimum performance.
See "git help gc" for manual housekeeping.
Checking out files: 100% (63293/63293), done.
Checked out HEAD:
  https://abc.xyz.com/svn/app1/path/to/proj2/B/trunk r218239
fatal: gc is already running on machine 'ppplwxzdw' pid 21345 (use --force if not)

然后我们检查提交历史

svngitTrunkrepo2]# git log -v

但我们只看到29次修订,而不是预期的198312修订版

git git-svn
1个回答
0
投票

消息

fatal: gc is already running on machine 'slc15zdw' pid 21345 (use --force if not)

表明git gc试图开始两次。同时你对git gc有相当奇怪的设置 - 特别是git config gc.auto 1意味着对于每个松散的物体,git gc将尝试开始。这适合上面的fatal消息。

尝试运行没有任何git svn参数的gc.* - 我认为它们弊大于利。

© www.soinside.com 2019 - 2024. All rights reserved.