× Aktuálně z oboru

SHIELD Experience Upgrade 7 – méně hledání a více zábavy [ clanek/2018052902-shield-experience-upgrade-7-mene-hledani-a-vice-zabavy/ ]
Celá zprávička [ clanek/2018052902-shield-experience-upgrade-7-mene-hledani-a-vice-zabavy/ ]

GitMagic (3) – klonování všude kolem

[ http://programujte.com/profil/10927-jakub-kulhan/ ]Google [ ?rel=author ]       [ http://programujte.com/profil/14523-martin-simecek/ ]Google [ ?rel=author ]       21. 6. 2009       11 926×

Klonování je základním způsobem, jak získat v distribuovaných verzovacích systémech, mezi které Git patří, kopii souborů, které jsou v repozitáři.

Ve starších verzovacích systémech byl checkout standardní operací k získání kupy souborů v požadovaném sta­vu.

V Gitu a jiných distribuovaných verzovacích systémech je klonování standardní operací. Abyste měli soubory, musíte udělat klon celého repozitáře. Jinými slovy vlastně zrcadlíte centrální server. Cokoli může dělat hlavní server, můžete vy také.

Synchronizace počítačů

Tohle byl důvod, proč jsem Git použil poprvé. Používat rsync nebo tarbally pro základní synchronizaci se dá snášet. Ale někdy potřebuju editovat na mém notebooku, jindy na mém desktopu. A počítače spolu nemusí být propojené.

Inicializujte Gití repozitář a proveďte commit vašich souborů na jednom počítači a na jiném:

$ git clone jiny.pocitac:/cesta/k/souborum

k získání druhé kopie souborů a vůbec celého repozitáře. Odteď:

$ git commit -a
$ git pull jiny.pocitac:/cesta/k/souborum HEAD

natáhne změny souborů na počítač, na kterém zrovna pracujete. Jestliže jste v poslední době provedli nějaké konfliktní změny, Git vám dá vědět a měli byste provést commit po jejich vyřešení.

Klasické verzování

Inicializujte Gití repozitář pro vaše soubory:

$ git init
$ git add .
$ git commit -m "Počáteční commit"

Na centrálním serveru inicializujte prázdný Gití repozitář se stejným jménem a spusťte Gitího démona, pokud je potřeba:

$ GIT_DIR=projekt.git git init
$ git daemon --detach  # už může běžet

Některé volně přístupné Gití hostingy, jako například repo.or.cz, budou používat jiné způsoby, jak vytvořit nový prázdný repozitář, např. odesláním webového formuláře.

Nastrkejte (push) data vašeho projektu na centrální server s:

$ git push git://centralni.server/projekt.git

Jsme hotovi. Když chce vývojář zdrojové soubory projektu, stačí když napíše:

$ git clone git://centralni.server/projekt.git

Po provedení změn je kód nahrán na hlavní server pomocí:

$ git commit -a
$ git pull

Fórkujeme

Nelíbí se vám, jakým směrem se projekt ubírá? Myslíte, že byste to dokázali lépe? Pak na vašem serveru:

$ git clone git://hlavni.server/projekt.git

A řekněte všechno o vašem forku projektu na vašem serveru.

Kdykoli později můžete sloučit změny z původního projektu pomocí:

$ git pull

Zálohy

Chcete četné geograficky různě rozmístěné rezervy? Pokud má váš projekt mnoho vývojářů, nedělejte vůbec nic! Každý klon repozitáře je záloha sama o sobě. Nejen momentálního stavu, ale celé historie projektu. Díky kryptografickému hashování se hned, jak je něčí klon poškozený, o tom dotyčný dozví při pokusu komunikovat s ostatními.

Pokud váš projekt tak populární není, najděte co nejvíce serverů, kde byste mohli klony projektu hostovat.

Opravdu paranoidní jedinci by si vždycky měli někde bezpečně poznamenat poslední 20-bytový SHA1 hash posledního commitu (HEAD). Mělo by to být na nějakém bezpečném místě, nemusí však vůbec být tajné. Například zveřejnění v novinách by mohlo být dobré, protože pro případného útočníka je velmi těžké změnit všechny kopie novin.

Děláme více věcí najednou rychlostí světla

Řekněme, že chcete pracovat na více funkcích současně. Pak proveďte commit a poté:

$ git clone . /nejaky/novy/adresar

Git k vytvoření tohoto klonu využívá hard linky a sdílení souborů co to jen jde, takže bude vytvořen v okamžiku. Nyní můžete pracovat na více funkcích v jeden a ten samý čas. Kupříkladu můžete editovat jeden klon, zatímco se druhý kompiluje.

Kdykoli můžete provést commit nebo pull.

$ git pull /puvodni/klon HEAD

Guerilla verzování

Pracujete na projektu, který používá jiný verzovací systém, a jen těžce snášíte, že nemůžete používat svůj Git? Pak vytvořte prázdný Gití repozitář ve vašem pracovním adresáři:

$ git init
$ git add .
$ git commit -m "Počáteční commit"

a naklonujte ho:

$ git clone . /nejaky/novy/adresar

Nyní přejděte do nového adresáře, pracujte zde a používejte při tom Git. Jestli chcete provést synchronizaci se všemi ostatními, přejděte do adresáře s originálním repozitářem, sychronizujte s jiným verzovacím systémem a napište:

$ git add .
$ git commit -m "Synchronizace s ostatními"

Potom přejděte do nového adresáře a spusťte:

$ git commit -a -m "Moje změny"
$ git pull

Postup k zpřístupnění vašich změn ostatním závisí na tom dalším verzovacím systému. Nový adresář obsahuje změněné soubory. Udělejte cokoli jiný verzovací systém potřebuje k nahrání změn do centrálního repozitáře.

git svn může zautomatizovat postup výše a může být též použit k exportu Gitího projektu do Subversion repozitáře.

Tento článek je překladem třetí kapitoly – Cloning Around [ http://www-cs-students.stanford.edu/~blynn/gitmagic/ch03.html ] – z GitMagic [ http://www-cs-students.stanford.edu/~blynn/gitmagic/ ] od Bena Lynna. V další kapitole se bude psát o větvení kódu.


Článek stažen z webu Programujte.com [ http://programujte.com/clanek/2009061701-gitmagic-3-klonovani-vsude-kolem/ ].