Azure DevOps TFVC 到 Git 的迁移

问题描述

我们正在研究在 Azure DevOps 中从 TFVC 迁移到 GIT 的可能性。有一个 tool 看起来应该对我们有用,但它不会将源代码移动到它创建的存储库中。我们的 TFVC 源代码树类似于以下结构。

  • $/Contoso
  • $/Contoso/GreatApp1
  • $/Contoso/GreatApp1/Main(分支)
  • $/Contoso/GreatApp1/Main/Source(包含源代码文件夹)
  • $/Contoso/GreatApp1/Main/Documentation(项目文档)
  • $/Contoso/GreatApp1/Dev(分支)
  • $/Contoso/GreatApp1/Dev/Source(包含源代码文件夹)
  • $/Contoso/GreatApp1/Dev/Documentation(项目文档)

至少,我想用文档和源代码转换主分支。我们在单个项目集合下有 40-50 个遵循这种结构的项目,所以理想情况下,我希望使用这个工具来做到这一点,而不必在所有不同的项目中重新绑定源代码控制。我想做的事情可行吗?

解决方法

导入体验针对小型、简单的 TFVC 存储库或已准备好迁移的存储库进行了优化。这意味着它有一些限制。

  1. 它只迁移根或分支的内容。例如,如果您在 $/Fabrikam 有一个 TFVC 项目,其中有 1 个分支和 1 个文件夹,则导入路径 $/Fabrikam 将导入文件夹,而 $/Fabrikam/<branch> 仅导入分支。
  2. 导入的存储库和相关历史记录(如果导入)的大小不能超过 1GB。
  3. 您最多可以导入 180 天的历史记录。

如果您想尝试使用 Git-TFS 进行高级迁移,该项目提供了有关如何从 TFVC 迁移到 Git、cloning a single branch with historycloning all branches with merge history 的文档。

让我们按照迁移指南并执行克隆命令:

git tfs clone {TFVC repo URL}

获取所有分支:

git tfs branch –init --all

对于每个分支,运行以下命令:

git checkout branch

git log -1

git tfs pull -c=changesetNumber

在 azure devops 中创建一个新的 repo 并获取 repo URL。然后在上游设置 git 存储库:

git remote add origin {New repo URL}

最后,您将所有本地更改推送到远程。

git push origin -u -all

有用的链接:

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...