如何解决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 存储库或已准备好迁移的存储库进行了优化。这意味着它有一些限制。
- 它只迁移根或分支的内容。例如,如果您在
$/Fabrikam
有一个 TFVC 项目,其中有 1 个分支和 1 个文件夹,则导入路径$/Fabrikam
将导入文件夹,而$/Fabrikam/<branch>
仅导入分支。 - 导入的存储库和相关历史记录(如果导入)的大小不能超过 1GB。
- 您最多可以导入 180 天的历史记录。
如果您想尝试使用 Git-TFS 进行高级迁移,该项目提供了有关如何从 TFVC 迁移到 Git、cloning a single branch with history 或 cloning 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
有用的链接:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。