


Cet article vous apporte des connaissances pertinentes sur Git, qui présente principalement les problèmes liés au rebase et le rebase peut être directement compris comme un changement de base. La branche de fonctionnalité est une branche basée sur B de la branche principale. La base de la fonctionnalité est B. J'espère que cela sera utile à tout le monde.
Étude recommandée : "Tutoriel d'apprentissage Git"
Cet article utilise l'exemple le plus simple pour vous aider à maîtriser rapidement le principe et l'utilisation du rebase
1 Soumettre un diagramme de nœuds
Tout d'abord, faites l'expérience du rebase via un simple. soumettre un diagramme de nœuds Que faites-vous
Deux branches master et feature, où feature est la branche extraite de master au point de soumission B
Il y a un nouveau commit M sur master, et il y a deux nouveaux commits C et D sur feature
Ceci Basculez vers la branche feature et exécutez la commande suivante, ce qui équivaut à fusionner la branche master dans la branche feature (le scénario de cette étape peut être comparé au fait que nous développons notre propre branche feature depuis un certain temps de temps et sont prêts à l'extraire de la branche principale principale) Découvrez les dernières modifications)
git checkout featuregit rebase master //这两条命令等价于git rebase master feature
L'image ci-dessous montre le diagramme du nœud de validation après le rebase, expliquez son principe de fonctionnement :
- fonctionnalité : branche à rebaser , branche actuelle
- master : branche de base, branche cible
Explication officielle (Si vous ne comprenez pas, vous pouvez lire directement le paragraphe suivant) : 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 pointer la branche à rebaser vers la base Le dernier commit de la branche, et enfin appliquer les modifications qui viennent d'être extraites à l'arrière du dernier commit de la branche de base. .
Expliqué avec des exemples : Lors de l'exécution de git rebase master sur la branche de fonctionnalité, git extraira les modifications sur la branche de fonctionnalité à partir de 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. Feature pointe naturellement vers D’ à la fin.
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. Et 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. (Notez que s'il n'y a pas de nouveaux commits sur le maître après B, alors le B d'origine sera toujours utilisé comme base. L'opération de rebase est équivalente à invalide. Pour le moment, il n'y a fondamentalement aucune différence avec git merge. Le seul la différence est que git merge aura un enregistrement supplémentaire de soumission d'opération de fusion)
L'exemple ci-dessus peut être résumé dans le scénario de travail réel suivant : Zhang San a extrait le code de B pour le développement et l'a soumis deux fois jusqu'à présent, et l'a développé en D ; Li Si l'a également extrait de B et l'a développé, il l'a soumis à M puis l'a fusionné dans le tronc principal. À ce moment-là, Zhang San voulait extraire le dernier code, il a donc exécuté git rebase master sur la branche feature, c'est-à-dire rebasé la branche master puisque Li Si avait développé et fusionné le tronc plus tôt, cela équivaut à Zhang San. sur la base de la dernière soumission de Li Si, M a été développé.
2. Exemple de soumission git réel
L'enregistrement de soumission est construit selon le diagramme ci-dessus, comme le montre la figure ci-dessous : (ABM est la ligne de branchement principale, ABCD est la ligne de branchement de fonctionnalité. Ici, la couleur principale change et débourse. Cela n'affecte pas la compréhension, sachez simplement que cela signifie deux branches et deux lignes !)
À ce stade, exécutez git rebase master sur la branche de fonctionnalité
Une fois le rebase terminé, ABCD est le embranchement de fonctionnalité d'origine, ABMC'D' C'est la nouvelle embranchement de fonctionnalité et ABM est l'embranchement principal (pas de changement)
3. Scénarios d'utilisation recommandés
Il y a tellement de choses à faire, mais ceci est en fait la chose la plus importante. Différentes entreprises et différentes situations ont différents scénarios d'utilisation, mais dans la plupart des cas, les recommandations sont les suivantes :
- Lorsque vous extrayez le dernier code d'une branche publique, utilisez rebase, c'est-à-dire git pull -r ou git pull --rebase, mais un inconvénient est qu'après le rebase, je ne sais pas quelle branche ma branche actuelle a été extraite en premier de. Parce que la base a changé. (Pour cette raison, la plupart des entreprises n'utilisent pas le rebase et utilisent essentiellement la fusion. Bien qu'il y ait un enregistrement de soumission dénué de sens « Fusionner… vers… », au moins elles peuvent savoir qui a fait quoi)
- Lors de la fusion de code dans un fichier public. branche, 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. Par exemple, Zhang San et Li Si ont tiré le développement d'une branche commune. Le nœud Zhang San a d'abord terminé le développement et en a soumis deux. Ensuite, la fusion a eu lieu, et Li Si l'a ensuite développé et rebasé (notez que Li Si doit passer à la branche principale, puis exécuter git rebase, puis git pull vers la branche distante. fin), alors la nouvelle soumission de Li Si devient la nouvelle de Zhang San. La nouvelle base soumise, à l'origine la soumission de Li Si était la dernière, mais la dernière soumission a montré que c'était celle de Zhang San à la place, et tout s'est mal passé)
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!

Git et Github ne sont pas la même chose: Git est un système de contrôle de version distribué, et GitHub est une plate-forme en ligne basée sur Git. Git aide les développeurs à gérer les versions de code et à réaliser la collaboration par la branche, la fusion et d'autres fonctions; GitHub fournit des fonctions d'hébergement, d'examen, de gestion des problèmes et d'interaction sociale, améliorant les capacités de collaboration de Git.

Après l'installation de Git, afin d'utiliser plus efficacement, les paramètres suivants sont requis: Définissez les informations de l'utilisateur (nom et boîte aux lettres) Sélectionnez l'éditeur de texte Définir l'outil de fusion externe Générer les paramètres de la clé SSH Ignorer le mode Fichier

Résolve: lorsque la vitesse de téléchargement GIT est lente, vous pouvez prendre les étapes suivantes: Vérifiez la connexion réseau et essayez de changer la méthode de connexion. Optimiser la configuration GIT: augmenter la taille du tampon post (Git Config - Global Http.PostBuffer 524288000) et réduire la limite à basse vitesse (Git Config - Global Http.LowspeedLimit 1000). Utilisez un proxy GIT (comme Git-Proxy ou Git-LFS-Proxy). Essayez d'utiliser un client GIT différent (comme SourceTree ou GitHub Desktop). Vérifiez la protection contre les incendies

Les causes de téléchargements lents GIT incluent de mauvaises connexions réseau, des problèmes de serveur GIT, des fichiers volumineux ou de grandes soumissions, des problèmes de configuration GIT, des ressources informatiques insuffisantes et d'autres facteurs tels que les logiciels malveillants. Les solutions de contournement comprennent l'amélioration de la connectivité réseau, l'ajustement des paramètres de pare-feu, d'éviter le téléchargement de fichiers ou de soumissions inutiles, d'optimiser la configuration GIT, de fournir des ressources informatiques adéquates et de numériser et de supprimer les logiciels malveillants.

Comment mettre à jour le code GIT local? Utilisez Git Fetch pour extraire les dernières modifications du référentiel distant. Fusionner les modifications à distance de la branche locale à l'aide de Git Merge Origin / & lt; Nom de la branche distante & gt;. Résoudre les conflits résultant des fusions. Utilisez Git commit -m "Merge Branch & lt; Remote Branch Name & gt;" Pour soumettre des modifications de fusion et appliquer les mises à jour.

Étapes pour mettre à jour le code GIT: Consultez le code: Git Clone https://github.com/username/repo.git Obtenez les derniers modifications: Git Fetch Merge Modifications: Git Merge Origin / Master Push Changes (Facultatif): Git Push Origin Master

Vous pouvez supprimer une branche GIT à travers les étapes suivantes: 1. Supprimer la branche locale: Utilisez la branche git -d & lt; Branch-name & gt; commande; 2. Supprimez la branche distante: utilisez le GIT PUSH & LT; Remote-Name & gt; --delete & lt; Branch-name & gt; commande; 3. Branche protégée: utilisez la branche Git Config. & lt; branche-name & gt;. Protected true pour ajouter les paramètres de branche de protection.

Processus de fusion du code GIT: tirez les dernières modifications pour éviter les conflits. Passez à la branche que vous souhaitez fusionner. Lancer une fusion, spécifiant la branche pour fusionner. Résoudre les conflits de fusion (le cas échéant). Stadification et engager la fusion, fournir un message de validation.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Télécharger la version Mac de l'éditeur Atom
L'éditeur open source le plus populaire

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.