Klonavimo pakatalogiai: greita apžvalga
Tvarkant versijos valdymą naudojant Git, skirtingiems scenarijams reikia skirtingų požiūrių, palyginti su senesnėmis sistemomis, tokiomis kaip SVN. Visų pirma, galimybė pasirinktinai klonuoti saugyklos pakatalogius gali būti labai svarbi įvairioms kūrimo darbo eigoms. Ši funkcija ypač naudinga, kai projekto struktūros yra sudėtingos arba kai reikia dirbti tik su saugyklos dalimi.
SVN buvo paprasta patikrinti pakatalogius iš saugyklos į skirtingas vietas. Tačiau „Git“ saugyklos duomenis tvarko skirtingai, todėl tiesioginiai SVN komandų atitikmenys, pvz., „svn co“, nėra tokie akivaizdūs. Šiame vadove bus nagrinėjama, kaip „Git“ gali pasiekti panašių rezultatų, naudodamas nedidelę patikrą ir kitas strategijas.
komandą | apibūdinimas |
---|---|
git init | Inicijuoja naują Git saugyklą, sukuria pradinį .git katalogą su visais reikalingais metaduomenimis. |
git remote add -f | Prideda naują nuotolinę saugyklą prie jūsų „Git“ konfigūracijos ir iš karto ją paima. |
git config core.sparseCheckout true | Įgalina retosios patikros funkciją, kuri leidžia iš dalies patikrinti saugyklą. |
echo "finisht/*" >> .git/info/sparse-checkout | Prideda kelią „finisht/*“ prie retosios patikros konfigūracijos failo, kad nustatytų, kurį pakatalogį reikia išsiregistruoti. |
git pull origin master | Ištraukia „pagrindinį“ atšaką iš „kilmės“ nuotolinio valdymo pulto, naudodamas retosios patikros taisykles, kad gautų tik nurodytus pakatalogius. |
git sparse-checkout set | Konfigūruoja kelius, kurie turi būti užpildyti darbo kataloge. |
Git Sparse Checkout ir scenarijaus darbo eigos paaiškinimas
Pateikti scenarijai skirti klonuoti konkrečius pakatalogius iš Git saugyklos, imituojant elgesį, kuris anksčiau buvo pasiekiamas naudojant SVN. Aplinkose, kuriose reikalingos tik tam tikros saugyklos dalys, tai gali žymiai sumažinti gaunamų duomenų skaičių ir pagerinti efektyvumą. Pirmajame scenarijuje naudojamas derinys git init, git remote add -f, ir git config core.sparseCheckout true Norėdami inicijuoti naują „Git“ saugyklą, pridėti nuotolinį šaltinį ir įgalinti nedidelį patikrą, leidžiančią pasirinktinai klonuoti saugyklos turinį.
Vėliau tokie keliai kaip „finisht/*“ pridedami prie retosios patikros konfigūracijos per echo komandas, nurodant Git gauti tik tuos konkrečius katalogus. Komanda git pull origin master naudojamas ištraukti tik sukonfigūruotus pakatalogius iš pagrindinės nuotolinės saugyklos šakos. Antrasis scenarijus naudoja git sparse-checkout set komandą, supaprastintą metodą, įdiegtą naujausiose „Git“ versijose, kuris supaprastina tiesioginį katalogo kelių nurodymą, padidina aiškumą ir kontrolę, kas išimama.
Klonavimo pakatalogių išskyrimas Git saugyklose
Bash ir Git komandų naudojimas
mkdir specific-dir-clone
cd specific-dir-clone
git init
git remote add -f origin https://your-repository-url.git
git config core.sparseCheckout true
echo "finisht/*" >> .git/info/sparse-checkout
git pull origin master
cd ..
mkdir another-specific-dir
cd another-specific-dir
git init
git remote add -f origin https://your-repository-url.git
git config core.sparseCheckout true
echo "static/*" >> .git/info/sparse-checkout
git pull origin master
„Git“ pakatalogių retosios patikros diegimas
Naudojant „Git Sparse-Checkout“ funkciją
git clone --filter=blob:none --no-checkout https://your-repository-url.git repo-dir
cd repo-dir
git sparse-checkout init --cone
git sparse-checkout set finisht
git checkout
cd ..
git clone --filter=blob:none --no-checkout https://your-repository-url.git another-repo-dir
cd another-repo-dir
git sparse-checkout init --cone
git sparse-checkout set static
git checkout
Pažangios Git technologijos, skirtos su katalogu susijusioms operacijoms
Be pagrindinių Git pakatalogių klonavimo metodų, yra ir pažangių metodų, kurie gali dar labiau optimizuoti, kaip kūrėjai valdo dideles saugyklas su daugeliu projektų. Vienas iš tokių metodų apima naudojimą git submodule. Ši komanda leidžia „Git“ saugyklai įtraukti kitas „Git“ saugyklas kaip submodulius, kuriuos galima klonuoti kartu su pirminiu, bet prižiūrėti atskirai. Tai ypač naudinga, kai reikia atskirti skirtingas saugyklos dalis, bet vis tiek valdyti iš centrinės saugyklos.
Kita išplėstinė funkcija yra naudojimas git filter-branch kartu su git subtree. Šis derinys leidžia išskleisti pakatalogį į naują, atskirą „Git“ saugyklą, išsaugant jo istoriją. Tai idealiai tinka situacijose, kai projektas išauga į savo esybę ir turi būti atskirtas nuo pagrindinės saugyklos neprarandant istorinio konteksto.
Pagrindiniai Git pakatalogių valdymo DUK
- Ar galiu klonuoti tik vieną katalogą iš Git saugyklos?
- Taip, naudojant tokias komandas kaip git sparse-checkout arba sukurti atskirą šaką tik su to katalogo turiniu.
- Kas yra retas išsiregistravimas Gite?
- Retas patikrinimas leidžia pasirinktinai patikrinti tam tikrus aplankus ar failus iš saugyklos neatsisiunčiant viso projekto.
- Kaip naudoti submodulį pakatalogiui?
- Pridėkite submodulį su git submodule add nurodant į norimą saugyklą ir kelią.
- Ar galiu atskirti pakatalogį į naują saugyklą?
- Taip, naudojant git subtree split sukurti naują šaką su pakatalogio istorija, kurią vėliau galima klonuoti.
- Kuo skiriasi git submodulis ir git submedis?
- Submoduliai susieja atskiras saugyklas su jūsų projektu kaip priklausomybes, o submedžiai sujungia kitą saugyklą su jūsų projektu ir gali ją išskaidyti.
Paskutinės mintys apie specifinį katalogų klonavimą Git
Nors „Git“ nesuteikia tiesioginės komandos, lygiavertės SVN patikrai atskiriems katalogams, naudojant retas patikros, submodulių ir submedžio strategijas galima rasti patikimų alternatyvų. Šie metodai ne tik atkartoja, bet dažnai pagerina senesnių versijų valdymo sistemų teikiamas funkcijas. Kūrėjams, pereinantiems nuo SVN arba tvarkantiems sudėtingus projektus Git sistemoje, šių metodų įsisavinimas gali žymiai supaprastinti kūrimo procesą.