Maison >outils de développement >git >Que signifie git rebase ?

Que signifie git rebase ?

青灯夜游
青灯夜游original
2021-12-29 17:04:3611624parcourir

git rebase signifie : redéfinir le statut du référentiel de la branche ; lors d'une opération de rebase, git extraira les modifications sur la branche à rebaser à partir de l'ancêtre commun des deux branches, puis pointera la branche à rebaser vers la branche de base Le dernier commit de la branche de base, et enfin appliquer les modifications qui viennent d'être extraites à l'arrière du dernier commit de la branche de base.

Que signifie git rebase ?

L'environnement d'exploitation de ce tutoriel : système Windows 7, Git version 2.30.0, ordinateur Dell G3.

Git rebase, comme son nom l'indique, consiste à redéfinir le rôle du point de départ (base), c'est-à-dire à redéfinir le statut du référentiel de la branche.

1. Diagramme de nœud de soumission

Tout d'abord, voyons ce que fait le rebase à travers un simple diagramme de nœud de soumission

Deux branches, master et feature, où feature est la branche extraite du maître au point de soumission B

Il y en a deux. branches sur master Un nouveau commit M et deux nouveaux commits C et D sur feature

Que signifie git rebase ?
À ce moment, passez à la branche feature et exécutez la commande suivante, ce qui équivaut à fusionner la branche master dans la branche feature

git checkout feature
git rebase master

//这两条命令等价于git rebase master feature

L'image ci-dessous montre le rebase. Le diagramme du nœud de soumission final explique son fonctionnement :

Que signifie git rebase ?

  • fonctionnalité : branche de base à modifier, branche actuelle
  • master : branche de base, branche cible

Explication officielle : lors de l'exécution une opération de rebase, git va partir de l'ancêtre commun des deux branches, extraire les modifications sur la branche à modifier, puis pointer la branche à modifier vers le dernier commit de la branche de base, et enfin appliquer les modifications qui viennent d'être extraites à au verso du dernier commit de la branche de base.

Explication avec exemples : Lors de l'exécution de git rebase master sur la branche feature, git extraira les modifications sur la branche feature en commençant par l'ancêtre commun B de master et featuer, c'est-à-dire que les deux commits C et D sont extraits en premier. Pointez ensuite la branche de fonctionnalité vers le dernier commit de la branche principale, qui est M. Enfin, les C et D extraits sont connectés à M, mais ce processus consiste à supprimer les C et D d'origine et à générer de nouveaux C' et D'. Leur contenu de soumission est le même, mais l'identifiant de validation est différent. Naturellement, la fonctionnalité pointe finalement vers D’.

Explication populaire (importante !) : le rebase peut être directement compris comme un changement de base. La branche de fonctionnalité est une branche extraite de B de la branche principale et la base de la fonctionnalité est B. Si master a un nouveau commit après B, cela équivaut à utiliser le nouveau commit sur master comme nouvelle base de la branche de fonctionnalités. L'opération réelle consiste à enregistrer les soumissions de la fonctionnalité après B, puis à supprimer les soumissions originales, puis à rechercher le dernier emplacement de soumission du maître, puis à connecter les soumissions enregistrées (nouveau nœud avec un nouvel identifiant de validation), de sorte que la base de la branche des fonctionnalités est tout à fait Yu est devenue M au lieu du B original.

Il existe également une explication très simple. La clé de la commande rebase est en fait de comprendre la "base". git rebase ). Soumettez ensuite à nouveau les soumissions différentielles une par une après le dernier point de soumission de la "branche de base", et enfin pointez le pointeur HEAD de la branche actuelle vers le dernier point de soumission


2. Exemple de soumission git réel

La soumission L'enregistrement est construit selon le diagramme ci-dessus, comme suit Comme le montre l'image : (ABM est la ligne de branchement principale et ABCD est la ligne de branchement de la fonctionnalité. Ici, le maître change de couleur et se ramifie. Cela n'affecte pas la compréhension. Juste sachez que cela signifie deux branches et deux lignes !)

Que signifie git rebase ?
Ceci lors de l'exécution de git rebase master sur la branche de fonctionnalité

Une fois le rebase terminé, ABCD est la ligne de branche de fonctionnalité d'origine, ABMC'D' est la nouvelle branche de fonctionnalité ligne, et ABM est la ligne secondaire principale (pas de changement)

Que signifie git rebase ?


3 Scénarios d'utilisation recommandés

Il y a tellement de choses à faire, mais c'est en fait la plus importante. Différentes entreprises et différentes situations ont des scénarios d'utilisation différents, mais dans la plupart des cas, les recommandations sont les suivantes :

  • Utilisez rebase lors de l'extraction du dernier code de la branche publique, c'est-à-dire git pull -r ou git pull --rebase, mais il y a un inconvénient à rebase. À partir de maintenant, je ne saurai plus de quelle branche ma branche actuelle a été extraite pour la première fois, car la base a changé. (Si vous utilisez la fusion, il y aura un enregistrement de validation dénué de sens "Fusionner... vers...")

  • Lors de la fusion de code dans une branche publique, utilisez la fusion. (Si vous utilisez rebase, alors si d'autres développeurs veulent voir l'historique de la branche principale, ce ne sera pas l'historique d'origine. L'historique a été falsifié par vous)

Apprentissage recommandé : "Tutoriel Git"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Article précédent:Que signifie gui dans git ?Article suivant:Que signifie gui dans git ?