Ceci est une ancienne révision du document !
Serveur Git
Installation
aptitude install git-core
Création/Initialisation d'un dépôt
Il y a certainement mieux pour initialiser mais bon. Voilà une méthode de A-Z d'initialisation d'un nouveau repos :
- En local sur un client :
mkdir mon_projet cd mon_projet git init
- Ensuite on y met nos premiers fichiers :
touch README
- On fait notre premier ajout/commit :
git add . git commit
- Ensuite on le clone au format bare :
cd .. git clone --bare monprojet monprojet.git
- Ensuite on met notre clone sur un serveur public :
scp -r monprojet.git/ user@srv:public_git/monprojet.git/
- On peut ensuite faire un clone du projet en local :
git clone ssh://user@srv/home/user/public_git/monprojet.git monprojet_local
- On peut maintenant utiliser ce clone normalement : add, commit, push, …
Mise en place d'un accès via git-daemon
- Éditer le fichier /etc/inetd.conf et ajouter la ligne suivante :
git stream tcp4 nowait root /usr/bin/git-daemon -- --inetd --syslog --verbose --export-all --base-path=[BASE] --timeout=60 --user-path=public_git
- [BASE] : le chemin de base de l'accès = la racine des urls d'accès
- Exemple:
- URL :
git://srv/toto
- [BASE] : /home
- Alors la racine du repos sera /home/toto
- –user-path : Le dossier dans les homes des utilisateurs qui seront partagé grâce à une URL en ~user (ici ~toto = $HOME/public_git)
- Restart openbsd-inetd : /etc/init.d/openbsd-inetd restart
Accès au serveur
Renseigner son profil git
git config --global user.email "user@email.com" git config --global user.name "User Name"
Remarque : Les infos sont stockées dans ˜/.gitconfig
Clone
- Via Git (Lecture~)
git clone git://srv/~toto/monprojet monprojet_local
- Via SSH (Lecture/Écriture)
git clone ssh://toto@srv/home/toto/public_git/monprojet monprojet_local
monprojet_local : Chemin local du repo
Utilisation courante
- Connaitre le statut des fichiers modifié/ajouté/supprimé
git status
- Ajouter un nouveau fichier
git add file1 file2 ...
- Supprimer un fichier
git rm file1
- Bouger/renomer un fichier
git mv file-old file-new
- Commiter (local)
git commit [-a]
- Envoyer ses commits sur le serveur remote
git push
- Récupérer les derniers commits des autres dans son repos
git pull
Remarque : C'est la même chose qu'un git fetch puis un git merge
- Voir la liste des commits :
git log
Remarque : On peut rajouter un nom de fichier pour voir seulement les commits impactant ce fichier.