SlideShare a Scribd company logo
1 of 13
Git et les systèmes de
    gestion de versions
          Pourquoi c'est bien
          Comment s'en servir


1                               Tälk #02 - alice@pulz.fr
De quoi s'agit-il ?

    • Maintenir l'ensemble des versions d'un ou plusieurs
    fichiers (exemple : l'historique Wikipedia)

    • Pouvoir rappeler une version antérieure à tout
    moment (révision)

    • Nécessité d'utiliser un logiciel
      • SVN
      • Mercurial
      • … ou Git
2                                             Tälk #02 - alice@pulz.fr
Intérêt

    • Pouvoir travailler en équipe facilement

    • Arrêter d'effacer les fichiers du collègue et perdre des
    données

    • Arrêter de se mélanger dans ses sauvegardes

    • Arrêter de faire des bêtises sur le FTP

    • Avoir une vision globale du projet
3                                               Tälk #02 - alice@pulz.fr
Git - Avantages
    • Travail hors ligne, la majorité des opérations est locale

    • Rapide

    • La quasi totalité des actions est réversible

    • Facilité dans la gestion des branches

    • Facile à utiliser




4                                                    Tälk #02 - alice@pulz.fr
Git - Les 3 états             (1/3)

    • Gestion des données en instantané (snapshot)
      • Instantané = état du répertoire à un instant t
      • Mini système de fichiers


    • 3 états de fichiers :
      • Validé : données stockées en bd locale
      • Modifié : fichier modifié, pas encore validé en base
      • Indexé : fichier marqué pour faire partie de la prochaine
        révision




5                                                        Tälk #02 - alice@pulz.fr
Git - Les 3 états               (2/3)



    • Répertoire git : ce qui est
      copié quand on clone un
      dépôt

    • Répertoire de travail :
      extraction unique d'une
      version du projet

    • Zone d'index : fichier qui
      stocke les infos concernant
      la prochaine révision




6                                           Tälk #02 - alice@pulz.fr
Git - Les 3 états           (3/3)




    • On modifie des fichiers dans son répertoire de travail

    • On indexe les fichiers modifiés
      • $ git add


    • On valide les modifications dans la base de données du
      répertoire git
      • $ git commit




7                                                  Tälk #02 - alice@pulz.fr
Démarrer un dépôt git existant

    • $ git clone git://github.com/schacon/grit.git
      • On récupère tout le repository en local
    • $ git add .
      • On indexe certains fichiers (ici, tous)
    • $ git commit -m ''mon message de commit''
      • On enregistre les changements sur le dépôt
    • $ git push origin master
      • On met à jour le dépôt distant, déploiement


    • Si quelqu'un a modifié le projet entre temps, on tire :
      • $ git pull

8                                                     Tälk #02 - alice@pulz.fr
Les branches          (1/2)




    • Branche : diverger de la ligne principale de
      développement

    • Pratique pour résoudre un bug, ou quand on a une super
      idée de nouveau module...

    • Git privilégie la création/fusion de branches comme
      méthode de travail



9                                                    Tälk #02 - alice@pulz.fr
Les branches              (2/2)


     • Créer une branche « correctif » :
       • $ git branch correctif
       • $ git checkout correctif
          • (ou $ git checkout -b correctif)


     • On a fini de travailler sur la branche
       • $ git checkout master
       • $ git merge correctif


     • On supprime la branche correctif
       • $ git branch -d correctif

10                                              Tälk #02 - alice@pulz.fr
Conflit

     • La fusion de branche n'a pas fonctionné
       automatiquement : conflit de fusion
       •   $ git status pour voir où se trouve le conflit
       •   On résout le conflit
       •   $ git add pour marquer le fichier comme résolu
       •   $ git status pour vérifier que tout va bien

     • On a tout cassé, besoin de revenir en urgence sur la
       branche principale
       • $ git stash retour à l'état d'origine



11                                                      Tälk #02 - alice@pulz.fr
Où héberger son dépôt ?

     • Github
       •   Gratuit pour l'open-source
       •   Joli
       •   Application pour Windows et Mac
       •   Grande communauté


     • Le NAS Pülz !
       • Git est installé
       • Et bientôt, Gitlab (interface graphique) !




12                                                    Tälk #02 - alice@pulz.fr
www.pulz.fr – Collectif effervescent de travailleurs indépendants




                         alice@pulz.fr

                        Source :
             http://git-scm.com/book/fr/



13                                                                 Tälk #02 - alice@pulz.fr

More Related Content

What's hot

What's hot (20)

GitHub - Présentation
GitHub - PrésentationGitHub - Présentation
GitHub - Présentation
 
Présentation Git & GitHub
Présentation Git & GitHubPrésentation Git & GitHub
Présentation Git & GitHub
 
Git pour les (pas si) nuls
Git pour les (pas si) nulsGit pour les (pas si) nuls
Git pour les (pas si) nuls
 
Introduction to Git and Github
Introduction to Git and GithubIntroduction to Git and Github
Introduction to Git and Github
 
Git - An Introduction
Git - An IntroductionGit - An Introduction
Git - An Introduction
 
Git
GitGit
Git
 
Git Started With Git
Git Started With GitGit Started With Git
Git Started With Git
 
Learning git
Learning gitLearning git
Learning git
 
A Practical Introduction to git
A Practical Introduction to gitA Practical Introduction to git
A Practical Introduction to git
 
Git - Basic Crash Course
Git - Basic Crash CourseGit - Basic Crash Course
Git - Basic Crash Course
 
Git utilisation quotidienne
Git   utilisation quotidienneGit   utilisation quotidienne
Git utilisation quotidienne
 
Git basics
Git basicsGit basics
Git basics
 
Git e GitHub - Conceitos Básicos
Git e GitHub - Conceitos BásicosGit e GitHub - Conceitos Básicos
Git e GitHub - Conceitos Básicos
 
Introduction to Git and Github
Introduction to Git and GithubIntroduction to Git and Github
Introduction to Git and Github
 
Introdução ao GitHub e Git
Introdução ao GitHub  e GitIntrodução ao GitHub  e Git
Introdução ao GitHub e Git
 
Git and github 101
Git and github 101Git and github 101
Git and github 101
 
Git and Github
Git and GithubGit and Github
Git and Github
 
Git the Docs: A fun, hands-on introduction to version control
Git the Docs: A fun, hands-on introduction to version controlGit the Docs: A fun, hands-on introduction to version control
Git the Docs: A fun, hands-on introduction to version control
 
Intro to Git and GitHub
Intro to Git and GitHubIntro to Git and GitHub
Intro to Git and GitHub
 
Git 101
Git 101Git 101
Git 101
 

Viewers also liked

Git: A Getting Started Presentation
Git: A Getting Started PresentationGit: A Getting Started Presentation
Git: A Getting Started Presentation
Nap Ramirez
 
Migration d'une base de code subversion vers git
Migration d'une base de code subversion vers gitMigration d'une base de code subversion vers git
Migration d'une base de code subversion vers git
Geoffrey Bachelet
 
Quick Introduction to git
Quick Introduction to gitQuick Introduction to git
Quick Introduction to git
Joel Krebs
 

Viewers also liked (19)

Getting Started on distributed version control with git
Getting Started on distributed version control with gitGetting Started on distributed version control with git
Getting Started on distributed version control with git
 
Git Ready! Worflows
Git Ready! WorflowsGit Ready! Worflows
Git Ready! Worflows
 
Git: A Getting Started Presentation
Git: A Getting Started PresentationGit: A Getting Started Presentation
Git: A Getting Started Presentation
 
Présentation du versioning avec Git
Présentation du versioning avec GitPrésentation du versioning avec Git
Présentation du versioning avec Git
 
Migration d'une base de code subversion vers git
Migration d'une base de code subversion vers gitMigration d'une base de code subversion vers git
Migration d'une base de code subversion vers git
 
SVN 2 Git
SVN 2 GitSVN 2 Git
SVN 2 Git
 
Basic Git Intro
Basic Git IntroBasic Git Intro
Basic Git Intro
 
Git 101 Presentation
Git 101 PresentationGit 101 Presentation
Git 101 Presentation
 
Getting Git Right
Getting Git RightGetting Git Right
Getting Git Right
 
Git 101: Git and GitHub for Beginners
Git 101: Git and GitHub for Beginners Git 101: Git and GitHub for Beginners
Git 101: Git and GitHub for Beginners
 
Tutorial Git
Tutorial GitTutorial Git
Tutorial Git
 
Quick Introduction to git
Quick Introduction to gitQuick Introduction to git
Quick Introduction to git
 
Formation JPA Avancé / Hibernate gratuite par Ippon 2014
Formation JPA Avancé / Hibernate gratuite par Ippon 2014Formation JPA Avancé / Hibernate gratuite par Ippon 2014
Formation JPA Avancé / Hibernate gratuite par Ippon 2014
 
Formation GIT gratuite par ippon 2014
Formation GIT gratuite par ippon 2014Formation GIT gratuite par ippon 2014
Formation GIT gratuite par ippon 2014
 
Formation Spring Avancé gratuite par Ippon 2014
Formation Spring Avancé gratuite par Ippon 2014Formation Spring Avancé gratuite par Ippon 2014
Formation Spring Avancé gratuite par Ippon 2014
 
Outils de gestions de versions
Outils de gestions de versionsOutils de gestions de versions
Outils de gestions de versions
 
En quoi git serait plus agile que svn ?
En quoi git serait plus agile que svn ?En quoi git serait plus agile que svn ?
En quoi git serait plus agile que svn ?
 
GitPourLaNulle
GitPourLaNulleGitPourLaNulle
GitPourLaNulle
 
Subversion - Utilisation et bonnes pratiques
Subversion - Utilisation et bonnes pratiquesSubversion - Utilisation et bonnes pratiques
Subversion - Utilisation et bonnes pratiques
 

Similar to Git et les systèmes de gestion de versions

GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...
GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...
GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...
akramalidrissi1
 
Cours sur github part3 git
Cours sur github part3 gitCours sur github part3 git
Cours sur github part3 git
Pape Diop
 
Git ou le renouveau du contrôle de version
Git ou le renouveau du contrôle de versionGit ou le renouveau du contrôle de version
Git ou le renouveau du contrôle de version
goldoraf
 
les commandes Git que vous devez absolument connaitre!.pdf
les commandes Git que vous devez absolument connaitre!.pdfles commandes Git que vous devez absolument connaitre!.pdf
les commandes Git que vous devez absolument connaitre!.pdf
SimpleLearn1
 

Similar to Git et les systèmes de gestion de versions (20)

Git pratique
Git pratiqueGit pratique
Git pratique
 
Git pratique
Git pratiqueGit pratique
Git pratique
 
Présentation du retour d'expérience sur Git
Présentation du retour d'expérience sur GitPrésentation du retour d'expérience sur Git
Présentation du retour d'expérience sur Git
 
Introduction à git.pdf
Introduction à git.pdfIntroduction à git.pdf
Introduction à git.pdf
 
Git vs SVN
Git vs SVNGit vs SVN
Git vs SVN
 
GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...
GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...
GIT & Future Branching-0d86ea39-71ad-4a19-940c-c10be7c33b08-9feea918-d69a-47e...
 
REX - Passage de CVS à Git
REX - Passage de CVS à GitREX - Passage de CVS à Git
REX - Passage de CVS à Git
 
GIT Fundamentals
GIT FundamentalsGIT Fundamentals
GIT Fundamentals
 
3_SCM_Git.pdf
3_SCM_Git.pdf3_SCM_Git.pdf
3_SCM_Git.pdf
 
Initiation à Git, GitHub2.pdf
Initiation à Git, GitHub2.pdfInitiation à Git, GitHub2.pdf
Initiation à Git, GitHub2.pdf
 
Utilisation de git avec Delphi
Utilisation de git avec DelphiUtilisation de git avec Delphi
Utilisation de git avec Delphi
 
JCertif 2012 : Git par la pratique
JCertif 2012 : Git par la pratiqueJCertif 2012 : Git par la pratique
JCertif 2012 : Git par la pratique
 
Petit Déjeuner Git chez Makina Corpus
Petit Déjeuner Git chez Makina CorpusPetit Déjeuner Git chez Makina Corpus
Petit Déjeuner Git chez Makina Corpus
 
Pourquoi versionner ses githooks.pdf
Pourquoi versionner ses githooks.pdfPourquoi versionner ses githooks.pdf
Pourquoi versionner ses githooks.pdf
 
Elasticsearch 5.0 les nouveautés
Elasticsearch 5.0 les nouveautésElasticsearch 5.0 les nouveautés
Elasticsearch 5.0 les nouveautés
 
Cours sur github part3 git
Cours sur github part3 gitCours sur github part3 git
Cours sur github part3 git
 
Débuter avec Git & github
Débuter avec Git & githubDébuter avec Git & github
Débuter avec Git & github
 
Git ou le renouveau du contrôle de version
Git ou le renouveau du contrôle de versionGit ou le renouveau du contrôle de version
Git ou le renouveau du contrôle de version
 
Git
GitGit
Git
 
les commandes Git que vous devez absolument connaitre!.pdf
les commandes Git que vous devez absolument connaitre!.pdfles commandes Git que vous devez absolument connaitre!.pdf
les commandes Git que vous devez absolument connaitre!.pdf
 

Git et les systèmes de gestion de versions

  • 1. Git et les systèmes de gestion de versions Pourquoi c'est bien Comment s'en servir 1 Tälk #02 - alice@pulz.fr
  • 2. De quoi s'agit-il ? • Maintenir l'ensemble des versions d'un ou plusieurs fichiers (exemple : l'historique Wikipedia) • Pouvoir rappeler une version antérieure à tout moment (révision) • Nécessité d'utiliser un logiciel • SVN • Mercurial • … ou Git 2 Tälk #02 - alice@pulz.fr
  • 3. Intérêt • Pouvoir travailler en équipe facilement • Arrêter d'effacer les fichiers du collègue et perdre des données • Arrêter de se mélanger dans ses sauvegardes • Arrêter de faire des bêtises sur le FTP • Avoir une vision globale du projet 3 Tälk #02 - alice@pulz.fr
  • 4. Git - Avantages • Travail hors ligne, la majorité des opérations est locale • Rapide • La quasi totalité des actions est réversible • Facilité dans la gestion des branches • Facile à utiliser 4 Tälk #02 - alice@pulz.fr
  • 5. Git - Les 3 états (1/3) • Gestion des données en instantané (snapshot) • Instantané = état du répertoire à un instant t • Mini système de fichiers • 3 états de fichiers : • Validé : données stockées en bd locale • Modifié : fichier modifié, pas encore validé en base • Indexé : fichier marqué pour faire partie de la prochaine révision 5 Tälk #02 - alice@pulz.fr
  • 6. Git - Les 3 états (2/3) • Répertoire git : ce qui est copié quand on clone un dépôt • Répertoire de travail : extraction unique d'une version du projet • Zone d'index : fichier qui stocke les infos concernant la prochaine révision 6 Tälk #02 - alice@pulz.fr
  • 7. Git - Les 3 états (3/3) • On modifie des fichiers dans son répertoire de travail • On indexe les fichiers modifiés • $ git add • On valide les modifications dans la base de données du répertoire git • $ git commit 7 Tälk #02 - alice@pulz.fr
  • 8. Démarrer un dépôt git existant • $ git clone git://github.com/schacon/grit.git • On récupère tout le repository en local • $ git add . • On indexe certains fichiers (ici, tous) • $ git commit -m ''mon message de commit'' • On enregistre les changements sur le dépôt • $ git push origin master • On met à jour le dépôt distant, déploiement • Si quelqu'un a modifié le projet entre temps, on tire : • $ git pull 8 Tälk #02 - alice@pulz.fr
  • 9. Les branches (1/2) • Branche : diverger de la ligne principale de développement • Pratique pour résoudre un bug, ou quand on a une super idée de nouveau module... • Git privilégie la création/fusion de branches comme méthode de travail 9 Tälk #02 - alice@pulz.fr
  • 10. Les branches (2/2) • Créer une branche « correctif » : • $ git branch correctif • $ git checkout correctif • (ou $ git checkout -b correctif) • On a fini de travailler sur la branche • $ git checkout master • $ git merge correctif • On supprime la branche correctif • $ git branch -d correctif 10 Tälk #02 - alice@pulz.fr
  • 11. Conflit • La fusion de branche n'a pas fonctionné automatiquement : conflit de fusion • $ git status pour voir où se trouve le conflit • On résout le conflit • $ git add pour marquer le fichier comme résolu • $ git status pour vérifier que tout va bien • On a tout cassé, besoin de revenir en urgence sur la branche principale • $ git stash retour à l'état d'origine 11 Tälk #02 - alice@pulz.fr
  • 12. Où héberger son dépôt ? • Github • Gratuit pour l'open-source • Joli • Application pour Windows et Mac • Grande communauté • Le NAS Pülz ! • Git est installé • Et bientôt, Gitlab (interface graphique) ! 12 Tälk #02 - alice@pulz.fr
  • 13. www.pulz.fr – Collectif effervescent de travailleurs indépendants alice@pulz.fr Source : http://git-scm.com/book/fr/ 13 Tälk #02 - alice@pulz.fr