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 stavu.
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 – z GitMagic od Bena Lynna. V další kapitole se bude psát o větvení kódu.