svn2git您使用的工具git-svn在后台使用,因此它不适合“快速转换”SVN 存储库。
有很多称为svn2git的工具,可能最好的一个是来自https://github.com/svn-all-fast-export/svn2git的 KDE 工具。我强烈建议使用该svn2git工具。这是我所知道的最好的,并且在你可以用它的规则文件做什么方面非常灵活。
您使用的工具svn2git基于git-svn并且git-svn不是用于一次性转换存储库或存储库部分的正确工具。如果您想使用 Git 作为现有 SVN 服务器的前端,这是一个很棒的工具,但对于一次性转换,您不应该使用,git-svn但svn2git它更适合这个用例。
If you are not 100% about the history of your repository, svneverever from http://blog.hartwork.org/?p=763 is a great tool to investigate the history of an SVN repository when migrating it to Git.
Even though git-svn (or the wrong svn2git in your case) is easier to start with, here are some further reasons why using the KDE svn2git instead of git-svn is superior, besides its flexibility:
- the history is rebuilt much better and cleaner by
svn2git (if the correct one is used), this is especially the case for more complex histories with branches and merges and so on
- the tags are real tags and not branches in Git
- with
git-svn the tags contain an extra empty commit which also makes them not part of the branches, so a normal fetch will not get them until you give --tags to the command as by default only tags pointing to fetched branches are fetched also. With the proper svn2git tags are where they belong
- if you changed layout in SVN you can easily configure this with
svn2git, with git-svn you will loose history eventually
- with
svn2git you can also split one SVN repository into multiple Git repositories easily
- or combine multiple SVN repositories in the same SVN root into one Git repository easily
- the conversion is a gazillion times faster with the correct
svn2git than with git-svn
There are many reasons why git-svn is worse and the KDE svn2git is superior. :-)