Git
Git est un logiciel de gestion de versions décentralisé. C'est un logiciel libre et gratuit, créé en 2005 par Linus Torvalds, auteur du noyau Linux, et distribué selon les termes de la licence publique générale GNU version 2. Le principal contributeur actuel de Git, et ce depuis plus de 16 ans, est Junio C Hamano.
Créateur | Linus Torvalds |
---|---|
Développé par | Software Freedom Conservancy (en) |
Première version | [1] |
Dernière version | 2.47.0 ()[2] |
Dépôt | git.kernel.org/pub/scm/git/git.git |
Assurance qualité | Intégration continue et intégration continue |
Écrit en | C, Perl, Tcl, Python et C++ |
Système d'exploitation | Multiplateforme |
Formats lus | Git packfile (d), git packfile index, version 1 (d) et git packfile index, version 2 (d) |
Formats écrits | Git packfile (d), git packfile index, version 1 (d) et git packfile index, version 2 (d) |
Langues | Anglais, bulgare, catalan, français, indonésien, suédois, turc, ukrainien, vietnamien, chinois simplifié et mandarin de Taïwan (d) |
Type |
Gestionnaire de code source décentralisé (en) Outil de science ouverte (d) Outil de programmation (en) Filestore (d) |
Licence | Licence publique générale GNU version 2 |
Site web | git-scm.com |
Depuis les années 2010, il s’agit du logiciel de gestion de versions le plus populaire dans le développement logiciel et web, qui est utilisé par des dizaines de millions de personnes, sur tous les environnements (Windows, Mac, Linux)[3]. Git est aussi le système à la base du célèbre site web GitHub, le plus important hébergeur de code informatique.
Origine du nom
modifierLinus Torvalds prononce [ˈɡɪt] avec un ɡ dur[4].
« git » peut se traduire par « connard » en argot britannique[5] ou désigne, d'après Merriam-Webster, une personne inconséquente ou sans valeur. Linus Torvalds explique à ce sujet « je ne suis qu'un sale égocentrique, donc j'appelle tous mes projets d'après ma propre personne. D'abord Linux, puis Git »[6].
Particularités techniques
modifierGit est similaire à BitKeeper en cela qu'il ne repose pas sur un serveur centralisé, mais utilise un système de connexion pair à pair. Le code informatique développé est stocké non seulement sur l’ordinateur de chaque contributeur du projet, mais il peut également l'être sur un serveur dédié. C'est un outil de bas niveau, qui se veut simple et performant, dont la principale tâche est de gérer l'évolution du contenu d'une arborescence.
Git indexe les fichiers d'après leur somme de contrôle calculée avec la fonction de hachage SHA‑1. Quand un fichier n'est pas modifié, la somme de contrôle ne change pas et le fichier n'est stocké qu'une seule fois. En revanche, si le fichier est modifié, les deux versions sont stockées sur le disque.
Contrastant avec les architectures de logiciel de gestion de versions habituellement utilisées jusqu'alors, Git repose entièrement sur un petit nombre de structures de données élémentaires. Linus Torvalds expliquait ainsi : « Par bien des aspects, vous pouvez considérer Git comme un simple système de fichiers. Il est adressé par contenu, et possède la notion de versionnement, mais je l'ai vraiment conçu en prenant le point de vue d'un spécialiste des systèmes de fichiers (après tout, j'ai l'habitude de travailler sur des noyaux) et je n'avais absolument aucune envie de créer un système de gestion de version traditionnel. »[7] Les premières versions de Git offraient une interface rudimentaire pour manipuler ces objets internes avant que les fonctionnalités courantes de gestion de version ne soient ensuite progressivement ajoutées et raffinées.
Git est considéré comme performant, au point que certains autres logiciels de gestion de version (Darcs, Arch), qui n'utilisent pas de base de données, se sont montrés intéressés par le système de stockage des fichiers de Git pour leur propre fonctionnement[8],[9]. Ils continuent toutefois à proposer des fonctionnalités plus évoluées.
Dès le début, Git a été pensé dans le but de fonctionner de façon décentralisée. La décentralisation de Git a beaucoup apporté au développement des logiciels libres, puisque le besoin de demander un compte sur un dépôt SVN ou CVS centralisé devient obsolète. Il suffit de forker un projet ou de le cloner pour commencer à travailler dessus (avec tout l'historique du projet en local) et ensuite de proposer sa contribution (pull request) au dépôt principal (mainteneur principal du projet).
Les serveurs Git utilisent par défaut le port 9418 pour le protocole spécifique à Git. Les protocoles HTTP, HTTPS et SSH (et leurs ports standards) peuvent aussi être utilisés.
Fonctionnement
modifierGit possède deux structures de données : une base d'objets et un cache de répertoires. Il existe quatre types d'objets :
- l'objet blob (pour binary large object désignant un ensemble de données brutes[10]), qui représente le contenu d'un fichier ;
- l'objet tree (mot anglais signifiant arbre), qui décrit une arborescence de fichiers. Il est constitué d'une liste d'objets de type blobs et des informations qui leur sont associées, tel que le nom du fichier et les permissions. Il peut contenir récursivement d'autres trees pour représenter les sous-répertoires ;
- l'objet commit (résultat de l'opération du même nom signifiant « valider une transaction »[11]), qui correspond à une arborescence de fichiers (tree) enrichie de métadonnées comme un message de description, le nom de l'auteur, etc. Il pointe également vers un ou plusieurs objets commit parents pour former un graphe d'historiques[10] ;
- l'objet tag (étiquette) qui est une manière de nommer arbitrairement un commit spécifique pour l'identifier plus facilement. Il est en général utilisé pour marquer certains commits, par exemple par un numéro ou un nom de version (2.1 ou bien Lucid Lynx).
La base des objets peut contenir n'importe quel type d'objets. Une couche intermédiaire, utilisant des index (les sommes de contrôle), établit un lien entre les objets de la base et l'arborescence des fichiers.
Chaque objet est identifié par une somme de contrôle SHA-1 de son contenu. Git calcule la somme de contrôle et utilise cette valeur pour déterminer le nom de fichier de l'objet. L'objet est placé dans un répertoire dont le nom correspond aux deux premiers caractères de la somme de contrôle. Le reste de la somme de contrôle constitue alors le nom du fichier pour cet objet.
Git enregistre chaque révision dans un fichier en tant qu'objet blob unique. Les relations entre les objets blobs sont déterminées en examinant les objets commit. En général, les objets blobs sont stockés dans leur intégralité en utilisant la compression de la zlib. Ce principe peut rapidement consommer une grande quantité de place disque ; de ce fait, les objets peuvent être combinés dans des archives, qui utilisent la compression différentielle (c'est-à-dire que les blobs sont enregistrés sous la forme de différences par rapport aux autres blobs).
Quelques commandes
modifierGit dispose notamment des commandes suivantes :
git init
crée un nouveau dépôt ;git clone
clone un dépôt distant ;git add
ajoute de nouveaux objets blobs dans la base des objets pour chaque fichier modifié depuis le dernier commit. Les objets précédents restent inchangés ;git commit
intègre la somme de contrôle SHA-1 d'un objet tree et les sommes de contrôle des objets commits parents pour créer un nouvel objet commit ;git branch
pour la gestion des branches ;git merge
fusionne une branche dans une autre ;git rebase
déplace les commits de la branche courante devant les nouveaux commits d’une autre branche ;git log
affiche la liste des commits effectués sur une branche ;git push
publie les nouvelles révisions sur le remote. (La commande prend différents paramètres) ;git pull
récupère les dernières modifications distantes du projet (depuis le Remote) et les fusionne dans la branche courante ;git stash
stocke de côté un état non commité afin d’effectuer d’autres tâches ;git checkout
annule les modifications effectuées, déplacement sur une référence (branche, hash) ;git switch
changement de branche ;git revert
défait les modifications d'un commit précédent ;git remote
gestion des remotes.
Interfaces
modifierInterfaces native
modifierEn tant qu'outil Open source, git est nativement doté d'une interface portable standard en ligne de commande pouvant fonctionner depuis divers types de terminaux.
Interfaces graphique native
modifierEn complément de l'interface native en ligne de commande, deux interfaces graphiques sont disponibles.
Une interface web est fournie en standard avec Git :
Deux interfaces graphiques sont proposées :
- git-gui : outil permettant les opérations git courantes, implémenté en Tcl/Tk ;
- gitk : est l'interface de visualisation détaillée et graphique d'un historique Git.
Interfaces de bureau tierces
modifierIl existe également d'autres applications offrant une interface de bureau :
- qgit propose des outils supplémentaires par rapport à gitk ;
- Giggle est une interface en GTK+ ;
- GitExtensions est un client Git graphique tournant sous Windows ;
- gitg est une interface graphique libre en GTK+, écrite en Vala ;
- JGit/EGit est une interface écrite en Java, puis une extension Git pour Eclipse ;
- SourceTree est un logiciel propriétaire gratuit compatible Windows et OS X édité par Atlassian permettant de gérer des dépôts Git et Mercurial (commit, merge, fetch, push…) ;
- GitKraken est un logiciel propriétaire permettant de gérer des dépôts Git ;
- Sublime Merge : permet de lire un dépôt git afin d'afficher le différentiel des dernières modifications, la liste des soumissions (commits) et les branches, parmi d'autres choses () ;
- tig est une interface texte libre (GPLv2), écrite en C ;
- TortoiseGit logiciel libre sous licence GPLv2, écrit en C/C++, reprend les éléments d'interface de TortoiseSVN ;
- Tower est un logiciel payant, uniquement pour OS X permettant la gestion de dépôts Git
Forges web pour auto-hébergement
modifierD'autres projets fournissent des interfaces web pour Git avec parfois gestion de différents projets, tickets, wiki… :
- Allura[12] de la fondation Apache, sous licence libre Apache 2.0[13], notamment utilisé par Sourceforge[14] ;
- Bitbucket[14] ;
- Bonobo Git Server[15], permet d'installer et d'administrer un serveur Git sur une plateforme Windows, écrit en C# .Net 4.6, sous licence MIT ;
- cgit, interface web libre (GPLv2) en C, écrite et utilisée par les auteurs du noyau Linux et de git et différents importants projets libres (KDE, tandis-que GNOME et Freedesktop.org l'ont utilisé avant de passer à une instance de Gitlab auto-hebérgée) ;
- AWS CodeCommit, intégré à la plate-forme de cloud computing Amazon Web Services[16] ;
- Gerrit, interface web libre en Java ;
- Gitalist est une interface web ;
- Gitblit est une interface web pour administrer et visualiser des dépôts Git ;
- Gitea une interface web sous licence MIT, écrite en langage Go[17] ;
- GitLab interface web avec gestion de groupes et tickets, développé en Ruby ;
- Gitorious, ancien projet communautaire libre, fermé et intégré a GitLab ;
- GitStack permet d'installer et d'administrer un serveur Git sur une plateforme Windows, implémenté en Python ;
- Gogs forge libre (licence MIT) complète, développé en Go ;
- Kallithea interface web libre (GPLv3) en Python pour Mercurial et Git[18] ;
- Phabricator, forge libre (licence Apache v2), en php, pour SVN, Git et Mercurial ;
- RhodeCode, forge libre (version community, différentes licences libres, et Entreprise payante) ;
- GNU Savannah, forge libre, servant à héberger le site homonyme, gère SVN, Mercurial et Git.
- kmx git, interface web pour serveur git (licence ISC).
Sites d’hébergement
modifierIl existe différents sites (également appelées forges) généralistes d'hébergement, ainsi que des sites dédiés à des développements en particulier, acceptant des projets liés d'utilisateur, comme l'instance cgit de Kernel.org (noyau Linux) ou les instances Gitlab de Freedesktop.org, GNOME, KDE ou encore de Blender.
- Framagit, site communautaire associatif libre de Framasoft, basé sur Gitlab.
- GitHub est un service web d'hébergement et de gestion de développement de logiciels développé en Ruby on Rails et Erlang, qui appartient à Microsoft depuis ;
- GitLab, équivalent à GitHub et développé en Ruby, évolution du code du service Gitorious, racheté en , le code source est disponible et utilisé par différentes autres forges ;
- GNU Savannah, permettant également l'utilisation de Mercurial, dépôt officiel de la Free Software Foundation ;
- SourceForge.net, probablement le plus ancien, ouvert en 1999, il utilisait CVS à ses débuts, avant de passer à Subversion (SVN), puis récemment à Git également. Il utilise aujourd'hui Apache Allura[14].
Développement
modifierGit a été spécialement développé et optimisé pour le noyau Linux. Linus Torvalds a commencé son écriture en avril 2005, pour remplacer le programme propriétaire BitKeeper. En effet, Larry McVoy a révoqué la possibilité d'utiliser gratuitement son logiciel, après qu'Andrew Tridgell eut tenté une rétro-ingénierie sur les protocoles utilisés par BitKeeper. Les raisons de cette révocation restent toutefois controversées.
La première version a été publiée le . Depuis, le développement de cet outil s'est poursuivi. Il a été progressivement amélioré, se voyant doté d'interfaces graphiques, d'interfaces web ou de scripts évolués.
Le Kernel Summit de a été l'occasion pour Linus Torvalds d'annoncer que les versions suivantes du noyau Linux (à partir de la version 2.6.12) seraient développées à l'aide de Git.
Fin , Linus Torvalds a décidé de confier la maintenance et les évolutions de Git à Junio Hamano, expliquant qu'il avait « toujours dit qu'il ne voulait pas vraiment le maintenir sur le long terme ».
Le développement est très actif. La parution de la première version stable (1.0) date du , soit moins d'un an après le démarrage du projet.
Pour des raisons de sécurité, des travaux pour passer l’algorithme de hashage de SHA-1, considéré plus assez sécurisé, à SHA-256 sont en préparations[19],[20].
Notes et références
modifier- « Re: Trivia: When did git self-host? » (consulté le )
- Junio Hamano (en), « [ANNOUNCE] Git v2.47.0 », (consulté le )
- (en) « Git 2.8.2 Popular Source Code Management System Released with Over 18 Bug Fixes », sur Softpedia, (consulté le )
- (en) « Tech Talk: Linus Torvalds on git », sur YouTube, (consulté le ).
- « Git », sur WordReference.com (consulté le ).
- (en) Robert McMillan, « After controversy, Torvalds begins work on "git" », sur PC World, .
- (en) Linus Torvalds, « 'Re: more git updates..' », (consulté le ) « In many ways you can just see git as a filesystem - it's content-addressable, and it has a notion of versioning, but I really really designed it coming at the problem from the viewpoint of a filesystem person (hey, kernels is what I do), and I actually have absolutely zero interest in creating a traditional SCM system. »
- git Archives: using git directory cache code in darcs?.
- [Gnu-arch-users] [ANNOUNCEMENT] /Arch/ embraces `git'.
- (en) Jon Loeliger, Version Control with Git, O'Reilly Media, Basic Git Concepts
- « Validation », sur gouv.qc.ca (consulté le ).
- (en) « Apache Allura », sur Apache Allura (consulté le )
- (en) « Allura »
- (en) James Sanders, « If Microsoft buying GitHub freaks you out, here are your best alternatives », sur TechRepublic,
- « Bonobo Git Server - Git Server for Windows », sur bonobogitserver.com (consulté le )
- AWS CodeCommit
- « Gitea », sur Gitea.io (consulté le ).
- « Kallithea », sur Scm.org (consulté le ).
- (en) Jonathan Corbet, « Whatever happened to SHA-256 support in Git? », sur LWN.net, (consulté le )
- (en) Michael Larabel, « Git 2.45 Begins Landing Code For SHA1 & SHA256 Interoperability For Repositories », sur Phoronix, (consulté le )
Voir aussi
modifierArticles connexes
modifierLiens externes
modifier- (en) Site officiel (maintenu par Scott Chacon)
- Git Livre communautaire Manuel de référence en français