Importera och migrera lagringsplatser från TFVC till Git
Azure DevOps Services | Azure DevOps Server 2022 – Azure DevOps Server 2019
Du kan migrera kod från en befintlig TFVC-lagringsplats till en ny Git-lagringsplats i samma organisation. Migrering till Git är en involverad process för stora TFVC-lagringsplatser och team. Centraliserade versionskontrollsystem, till exempel TFVC, beter sig annorlunda än Git på grundläggande sätt. Växeln innebär mycket mer än att lära sig nya kommandon. Det är en störande förändring som kräver noggrann planering. Du måste tänka på:
- Revidera verktyg och processer
- Ta bort binärfiler och körbara filer
- Träna ditt team
Vi rekommenderar starkt att du läser centraliserad versionskontroll till Git och följande avsnitt Migrera från TFVC till Git innan du påbörjar migreringen.
Importupplevelsen är bra för små enkla TFVC-lagringsplatser. Det är också bra för lagringsplatser som redan har "rensats" enligt beskrivningen i centraliserad versionskontroll till Git och följande migrering från TFVC till Git.It's also good for repositories that have already been "cleaned up" as outlined in Centralized version control to Git and the following Migrate from TFVC to Git section. De här avsnitten rekommenderar även andra verktyg för mer avancerade TFVC-lagringsplatskonfigurationer.
Viktigt!
På grund av skillnaderna i hur TFVC- och Git Store-versionskontrollhistoriken skiljer sig åt rekommenderar vi att du inte migrerar din historik. Detta är den metod som Microsoft använde när de migrerade Windows och andra produkter från centraliserad versionskontroll till Git.
Importera lagringsplatsen
Välj Lagringsplatser, Filer.
I listrutan på lagringsplatsen väljer du Importera lagringsplats.
Välj TFVC i listrutan Källtyp
Skriv sökvägen till den lagringsplats/gren/mapp som du vill importera till Git-lagringsplatsen. Till exempel:
$/Fabrikam/FabrikamWebsite
Om du vill migrera historik från TFVC-lagringsplatsen klickar du på Migrera historik och väljer antalet dagar. Du kan migrera upp till 180 dagars historik från den senaste ändringsuppsättningen. En länk till TFVC-lagringsplatsen läggs till i incheckningsmeddelandet för den första ändringsuppsättningen som migreras till Git. Det gör det enkelt att hitta äldre historik när det behövs.
Ge ett namn till den nya Git-lagringsplatsen och klicka på Importera. Beroende på storleken på importen är Git-lagringsplatsen klar om några minuter.
Felsökning
Den här upplevelsen är optimerad för små, enkla TFVC-lagringsplatser eller lagringsplatser som har förberetts för en migrering. Det innebär att den har några begränsningar.
- Den migrerar bara innehållet i roten eller en gren. Om du till exempel har ett TFVC-projekt
$/Fabrikam
där det finns en gren och en mapp under sig, skulle en sökväg till importen$/Fabrikam
importera mappen medan$/Fabrikam/<branch>
endast grenen skulle importeras. - Den importerade lagringsplatsen och tillhörande historik (om den importeras) får inte överstiga 1 GB i storlek.
- Du kan importera upp till 180 dagars historik.
Om något av ovanstående är en blockerare för din import rekommenderar vi att du provar externa verktyg som Git-TFS för att importera och läsa våra whitepapers – Centraliserad versionskontroll till Git och följande avsnittet Migrera från TFVC till Git.
Viktigt!
Användningen av externa verktyg som Git-TFS med Microsofts produkter, tjänster eller plattformar är helt användarens ansvar. Microsoft stöder inte, stöder eller garanterar funktionalitet, tillförlitlighet eller säkerhet för sådana tillägg från tredje part.
Migrera från TFVC till Git
Innan du migrerar källkod från ett centraliserat versionskontrollsystem till Git ska du förstå skillnaderna mellan de två och förbereda migreringen.
Krav
För att underlätta migreringen finns det ett antal krav innan du importerar lagringsplatsen i föregående avsnitt i den här artikeln.
- Migrera endast en enda gren. När du planerar migreringen väljer du en ny förgreningsstrategi för Git. Om du bara migrerar huvudgrenen stöds ett ämnesgrensbaserat arbetsflöde som GitFlow eller GitHub Flow.
- Utför en tipsmigrering, precis som i, importera endast den senaste versionen av källkoden. Om TFVC-historiken är enkel finns det ett alternativ för att migrera viss historik, upp till 180 dagar, så att teamet bara kan arbeta från Git. Mer information finns i Planera migreringen till Git.
- Undanta binära tillgångar som bilder, vetenskapliga datauppsättningar eller spelmodeller från lagringsplatsen. Dessa tillgångar bör använda Git LFS-tillägget (Large File Storage), som importverktyget inte konfigurerar.
- Behåll den importerade lagringsplatsen under 1 GB i storlek.
Om lagringsplatsen inte uppfyller dessa krav använder du Git-TFS-verktyget för att utföra migreringen i stället.
Viktigt!
Användningen av externa verktyg som Git-TFS med Microsofts produkter, tjänster eller plattformar är helt användarens ansvar. Microsoft stöder inte, stöder eller garanterar funktionalitet, tillförlitlighet eller säkerhet för sådana tillägg från tredje part.
Migreringssteg
Processen för att migrera från TFVC är vanligtvis enkel:
- Kolla in den senaste versionen av grenen från TFVC på din lokala disk.
- Ta bort binärfiler och byggverktyg från lagringsplatsen och konfigurera ett pakethanteringssystem som NuGet.
- Konvertera versionskontrollspecifika konfigurationsdirektiv . Du kan till exempel konvertera
.tfignore
filer till.gitignore
och konvertera.tpattributes
filer till.gitattributes
. - Kontrollera ändringarna och utför migreringen till Git.
Steg 1–3 är valfria. Om det inte finns några binärfiler på lagringsplatsen och det inte finns något behov av att konfigurera en .gitignore
eller en .gitattributes
kan du fortsätta direkt till checka in ändringar och utföra migreringssteget .
Kolla in den senaste versionen
Skapa en ny TFS-arbetsyta och mappa en arbetsmapp för serverkatalogen som migreras till Git. Detta kräver inte en fullständig mappmappning. Mappa endast mappar som innehåller binärfiler som ska tas bort från lagringsplatsen och mappar som innehåller systemspecifika konfigurationsfiler för versionskontroll som .tfignore
.
När mappningarna har konfigurerats hämtar du mappen lokalt:
tf get /version:T /recursive
Ta bort binärfiler och byggverktyg
På grund av hur Git lagrar historiken för ändrade filer genom att tillhandahålla en kopia av varje fil i historiken till varje utvecklare, gör kontrollen av binära filer direkt till lagringsplatsen att lagringsplatsen växer snabbt och kan orsaka prestandaproblem.
För byggverktyg och beroenden som bibliotek använder du en paketeringslösning med versionsstöd, till exempel NuGet. Många verktyg och bibliotek med öppen källkod är redan tillgängliga i NuGet-galleriet, men för egna beroenden skapar du nya NuGet-paket.
När beroenden har flyttats till NuGet ska du se till att de inte ingår i Git-lagringsplatsen genom att lägga till dem i .gitignore
.
Konvertera versionskontrollspecifik konfiguration
Team Foundation Version Control tillhandahåller en .tfignore
fil som säkerställer att vissa filer inte läggs till i TFVC-lagringsplatsen. Du kan använda .tfignore
filen för automatiskt genererade filer som build-utdata så att de inte checkas in av misstag.
Om projektet förlitar sig på det här beteendet konverterar du .tfignore
filen till en .gitignore
fil.
TFVC-klienter mellan plattformar ger också stöd för en .tpattributes
fil som styr hur filer placeras på den lokala disken eller checkas in på lagringsplatsen. Om en .tpattributes
fil används konverterar du den till en .gitattributes
fil.
Kontrollera ändringarna och utför migreringen
Kontrollera eventuella ändringar som tar bort binärfiler, migrerar till pakethantering eller konverterar versionskontrollspecifik konfiguration. När du gör den här slutliga ändringen i TFVC kan du göra importen.
Följ proceduren Importera lagringsplatsen för att utföra importen.
Avancerade migreringar
Git-TFS-verktyget är en dubbelriktad brygga mellan Team Foundation Version Control och Git, och du kan använda det för att utföra en migrering. Git-TFS är lämpligt för en migrering med fullständig historik, mer än de 180 dagar som importverktyget stöder. Eller så kan du använda Git-TFS för att försöka migrering som innehåller flera grenar och sammanslagningsrelationer.
Innan du försöker migrera med Git-TFS bör du tänka på att det finns grundläggande skillnader mellan HUR TFVC och Git Store-historik:
- Git lagrar historiken som en ögonblicksbild av lagringsplatsen i tid, medan TFVC registrerar de diskreta åtgärder som inträffade på en fil. Ändringstyper i TFVC som byt namn, ta bort borttagning och återställning kan inte uttryckas i Git. I stället för att se att filen
A
har bytt namn till filenB
spårar den bara att filenA
har tagits bort och filenB
lades till i samma incheckning. - Git har ingen direkt analog till en TFVC-etikett. Etiketter kan innehålla valfritt antal filer i valfri specifik version och kan återspegla filer i olika versioner. Även om git-taggarna är konceptuellt likartade pekar de på en ögonblicksbild av hela lagringsplatsen vid en viss tidpunkt. Om projektet förlitar sig på TFVC-etiketter för att veta vad som levererades kanske Git-taggarna inte ger den här informationen.
- Sammanslagningar i TFVC sker på filnivå, inte på hela lagringsplatsen. Endast en delmängd av ändrade filer kan sammanfogas från en gren till en annan. Återstående ändrade filer kan sedan sammanfogas i en efterföljande ändringsuppsättning. I Git påverkar en sammanslagning hela lagringsplatsen, och båda uppsättningarna med enskilda ändringar kan inte ses som en sammanslagning.
På grund av dessa skillnader rekommenderar vi att du gör en tipsmigrering och håller TFVC-lagringsplatsen online, men skrivskyddad, för att visa historik.
Om du vill prova en avancerad migrering med Git-TFS kan du läsa klona en enda gren med historik eller klona alla grenar med sammanslagningshistorik.
Viktigt!
Användningen av externa verktyg som Git-TFS med Microsofts produkter, tjänster eller plattformar är helt användarens ansvar. Microsoft stöder inte, stöder eller garanterar funktionalitet, tillförlitlighet eller säkerhet för sådana tillägg från tredje part.
Uppdatera arbetsflödet
Att flytta från ett centraliserat versionskontrollsystem till Git är mer än att bara migrera kod. Teamet behöver utbildning för att förstå hur Git skiljer sig från det befintliga versionskontrollsystemet och hur dessa skillnader påverkar det dagliga arbetet.
Läs mer om hur du migrerar från centraliserad versionskontroll till Git.