Comprendre i solucionar els conflictes de fusió de Git
Fer front als conflictes de combinació en un dipòsit de Git és un repte comú per als desenvolupadors. Pot ser frustrant quan diversos canvis a la mateixa part d'un fitxer causen conflictes que necessiten una resolució manual.
En aquesta guia, us explicarem els passos per identificar, resoldre i prevenir conflictes de combinació. Entendre aquests conceptes us ajudarà a mantenir un flux de treball fluid i eficient en els vostres projectes.
Comandament | Descripció |
---|---|
git fetch origin | Obtén les actualitzacions del dipòsit remot sense combinar-les. Útil per comprovar si hi ha nous canvis abans de combinar-los. |
git merge origin/main | Combina la branca especificada (origen/principal) amb la branca actual. Si hi ha conflictes, caldrà resoldre'ls manualment. |
git add <resolved-file> | Afegeix els fitxers resolts a l'àrea de prova, preparant-los per a la següent confirmació. |
git commit -m "Resolved merge conflicts" | Crea una confirmació nova amb un missatge que indica que s'han resolt els conflictes de combinació. |
git push origin main | Envia les confirmacions locals al dipòsit remot, actualitzant la branca remota amb els conflictes resolts. |
GitLens UI | Una característica de l'extensió GitLens a Visual Studio Code que proporciona una interfície gràfica per visualitzar i resoldre conflictes de combinació. |
Explicació de la resolució de conflictes de fusió
El primer script se centra a utilitzar ordres de Git per resoldre conflictes de combinació mitjançant la interfície de línia d'ordres. Comença amb git fetch origin, que obté les actualitzacions del repositori remot sense combinar-les. Això és seguit per git merge origin/main, que intenta combinar els canvis de la branca principal remota a la branca actual. Si hi ha conflictes, heu d'obrir manualment cada fitxer en conflicte i resoldre'ls. Després de resoldre, feu servir git add <resolved-file> per escenificar els fitxers resolts.
Aleshores, creeu un nou compromís amb git commit -m "Resolved merge conflicts" per finalitzar la fusió. El pas final és enviar els canvis resolts al repositori remot mitjançant git push origin main. El segon script demostra l'ús de l'extensió GitLens a Visual Studio Code, que proporciona una interfície gràfica per resoldre conflictes. Us guia a través de l'extracció dels darrers canvis, utilitzant la interfície d'usuari de GitLens per resoldre conflictes i, a continuació, organitzar, confirmar i impulsar els canvis mitjançant els controls integrats.
Resolució de conflictes de combinació mitjançant ordres de Git
Interfície de línia d'ordres de Git Bash
# Step 1: Fetch the latest changes from the remote repository
git fetch origin
# Step 2: Merge the remote branch into your current branch
git merge origin/main
# Step 3: Identify and resolve conflicts
# Open each conflicted file in your editor and resolve manually
# Step 4: After resolving conflicts, add the resolved files
git add <resolved-file>
# Step 5: Complete the merge
git commit -m "Resolved merge conflicts"
# Step 6: Push the changes to the remote repository
git push origin main
Ús d'una eina GUI per resoldre conflictes de combinació
Visual Studio Code amb extensió GitLens
# Step 1: Open your project in Visual Studio Code
# Step 2: Install the GitLens extension if not already installed
# Step 3: Use the Source Control panel to pull the latest changes
# Step 4: When conflicts occur, navigate to the conflicted files
# Step 5: Use the GitLens UI to view and resolve conflicts
# Step 6: After resolving, stage the changes
# Step 7: Commit the resolved changes
# Step 8: Push the changes to the remote repository
Gestió de conflictes de combinació complexos amb Rebase
Un altre enfocament per resoldre els conflictes de combinació és l'ús git rebase. La rebase us permet moure o combinar una seqüència de commits a una nova commit base. Això pot ajudar a crear un historial de projectes més net evitant commits de fusió innecessaris. Per canviar la base de la vostra branca actual en una altra branca, feu servir git rebase <branch>. Durant el procés de rebase, si hi ha conflictes, Git s'aturarà i us permetrà resoldre'ls de manera similar a un conflicte de combinació.
Després de resoldre els conflictes, utilitzeu git rebase --continue per continuar amb la rebase. Si necessiteu avortar el procés de rebase en qualsevol moment, podeu utilitzar git rebase --abort. El canvi de base s'ha d'utilitzar amb cura, especialment a les branques compartides, ja que reescriu l'historial de confirmació. Entendre i utilitzar rebase amb eficàcia pot conduir a una història del projecte més racionalitzada i comprensible.
Preguntes habituals sobre la resolució de conflictes de fusió de Git
- Què és un conflicte de combinació a Git?
- Un conflicte de combinació es produeix quan es fan diversos canvis a la mateixa part d'un fitxer en branques diferents i Git no els pot combinar automàticament.
- Com començo a resoldre un conflicte de combinació?
- Podeu començar a resoldre un conflicte de combinació executant-lo git merge i després editar manualment els fitxers en conflicte.
- El que fa git fetch fer?
- git fetch recupera les actualitzacions del dipòsit remot però no les fusiona amb la vostra branca actual.
- Com puc completar una fusió després de resoldre els conflictes?
- Després de resoldre els conflictes, escenifiqueu els canvis amb git add, comprometre'ls amb git commit, i empènyer-los utilitzant git push.
- Quina és la diferència entre git merge i git rebase?
- git merge crea una confirmació de combinació combinant canvis, mentre git rebase reescriu l'historial de commits per crear una seqüència lineal de commits.
- Quan l'he d'utilitzar git rebase?
- Ús git rebase quan voleu crear un historial de projectes més net i evitar commits de combinació innecessaris, però feu-lo servir amb cura a les branques compartides.
- Com puc avortar una rebase?
- Podeu avortar un procés de rebase en qualsevol moment utilitzant git rebase --abort.
- Quines eines poden ajudar a resoldre els conflictes de combinació?
- Eines com Visual Studio Code amb l'extensió GitLens ofereixen una interfície gràfica per ajudar a resoldre els conflictes de combinació més fàcilment.
Resolució de conflictes de fusió
En conclusió, resoldre conflictes de combinació en un dipòsit de Git implica comprendre les complexitats de les ordres i les eines de Git. Utilitzant eficaçment git fetch, git merge, i altres ordres, així com eines GUI com GitLens, els desenvolupadors poden mantenir un flux de treball net i eficient. Abordar els conflictes de manera ràpida i precisa ajuda a mantenir l'historial de compromisos del projecte net i la col·laboració perfecta. Tant si preferiu la línia d'ordres com les interfícies gràfiques, dominar aquestes tècniques és essencial per a qualsevol desenvolupador que treballi amb Git.