Git » Historique » Version 6
Version 5 (Antoine Lubineau, 21/02/2012 19:43) → Version 6/69 (Antoine Lubineau, 21/02/2012 19:44)
h1. Installation et utilisation dâun serveur Git
Les explications qui suivent ont été appliquées sur le serveur @git.tetaneutral.net@ de Tetaneutral.net, donc avec une Debian Squeeze.
"Git":http://git-scm.com/ est un gestionnaire de versions décentralisé, libre et développé en C. à noter la traduction française du "Git community book":http://www.alexgirard.com/git-book/index.html.
La configuration se fera essentiellement au travers de "Gitolite":https://github.com/sitaramc/gitolite, qui permet de créer des dépôts, gérer les accès push/pull pour des accès en SSH, déléguer des droits, etc. @git-daemon@ permet de donner un accès au travers du protocole @git@, et @cgit@ sera utilisé pour lâinterface web.
h2. "Gitolite":https://github.com/sitaramc/gitolite
h3. Installation
h3. Configuration
h2. git-daemon
h2. "cgit":http://hjemli.net/git/cgit/
h3. Installation
Comme il nây a pas de paquet Debian, il faut le compiler à la main. Au moment de la rédaction de ce guide, on ne pouvait pas compiler cgit contre la dernière version de Git (fonctionnel avec cgit 0.9.2.0 et Git 1.7.4).
<pre>
wget
</pre>
Avec les sources de Git 1.7.4, en spécifiant @CGIT_SCRIPT_PATH = /var/www@ et @prefix = /usr/local/cgit@ dans le @Makefile@.
h3. Configuration
Pour que le serveur web ait les droits de lecture sur les dépôts, il faut ajouter lâutilisateur @www-data@ au groupe @git@ :
<pre>
usermod -aG git www-data
</pre>
Faire un @chmod -R g+rX@ sur les dépôts existants (*pas gitolite-admin.git*), et changer
<pre>
$REPO_UMASK @$REPO_UMASK = 0077;
</pre>
0077;@ en
<pre>
$REPO_UMASK @$REPO_UMASK = 0027;
</pre>
0027;@ dans @~git/.gitolite.rc@ (ce réglage ne vaut que pour les dépôts qui seront créés par la suite).
cgit récupère la liste des projets dans @~git/projects.list@. Cette liste est complétée par Gitolite pour les dépôts dont @gitweb@ a les droits en lecture (câest une dénomination spécifique à gitolite, qui nâest pas incluse dans @@all@).
La configuration de @cgit@ se trouve dans @cgitrc(5)@ :
<pre>
virtual-root=/
project-list=/home/git/projects.list
scan-path=/home/git/repositories/
</pre>
Pour spécifier le propriétaire et la description dâun dépôt, voir le "manuel de gitolite":http://sitaramc.github.com/gitolite/confother_.html, section «â¯specifying gitweb and daemon accessâ¯Â».
Les explications qui suivent ont été appliquées sur le serveur @git.tetaneutral.net@ de Tetaneutral.net, donc avec une Debian Squeeze.
"Git":http://git-scm.com/ est un gestionnaire de versions décentralisé, libre et développé en C. à noter la traduction française du "Git community book":http://www.alexgirard.com/git-book/index.html.
La configuration se fera essentiellement au travers de "Gitolite":https://github.com/sitaramc/gitolite, qui permet de créer des dépôts, gérer les accès push/pull pour des accès en SSH, déléguer des droits, etc. @git-daemon@ permet de donner un accès au travers du protocole @git@, et @cgit@ sera utilisé pour lâinterface web.
h2. "Gitolite":https://github.com/sitaramc/gitolite
h3. Installation
h3. Configuration
h2. git-daemon
h2. "cgit":http://hjemli.net/git/cgit/
h3. Installation
Comme il nây a pas de paquet Debian, il faut le compiler à la main. Au moment de la rédaction de ce guide, on ne pouvait pas compiler cgit contre la dernière version de Git (fonctionnel avec cgit 0.9.2.0 et Git 1.7.4).
<pre>
wget
</pre>
Avec les sources de Git 1.7.4, en spécifiant @CGIT_SCRIPT_PATH = /var/www@ et @prefix = /usr/local/cgit@ dans le @Makefile@.
h3. Configuration
Pour que le serveur web ait les droits de lecture sur les dépôts, il faut ajouter lâutilisateur @www-data@ au groupe @git@ :
<pre>
usermod -aG git www-data
</pre>
Faire un @chmod -R g+rX@ sur les dépôts existants (*pas gitolite-admin.git*), et changer
<pre>
$REPO_UMASK @$REPO_UMASK = 0077;
</pre>
0077;@ en
<pre>
$REPO_UMASK @$REPO_UMASK = 0027;
</pre>
0027;@ dans @~git/.gitolite.rc@ (ce réglage ne vaut que pour les dépôts qui seront créés par la suite).
cgit récupère la liste des projets dans @~git/projects.list@. Cette liste est complétée par Gitolite pour les dépôts dont @gitweb@ a les droits en lecture (câest une dénomination spécifique à gitolite, qui nâest pas incluse dans @@all@).
La configuration de @cgit@ se trouve dans @cgitrc(5)@ :
<pre>
virtual-root=/
project-list=/home/git/projects.list
scan-path=/home/git/repositories/
</pre>
Pour spécifier le propriétaire et la description dâun dépôt, voir le "manuel de gitolite":http://sitaramc.github.com/gitolite/confother_.html, section «â¯specifying gitweb and daemon accessâ¯Â».