Entendiendo Git
  • Introduction
  • Nucleo git: como almacena git
  • El primer commit
  • Versionamiento
  • Tags / Etiquetas
  • Branches
  • Merges
  • Rebases
  • Distributed Version Control
  • Social
Powered by GitBook
On this page
  • Diferentes ventajas y desventajas
  • Merge
  • Rebase

Was this helpful?

Rebases

PreviousMergesNextDistributed Version Control

Last updated 5 years ago

Was this helpful?

La ilustración describe un escenario para el comando rebase.

Hay dos maneras de poner las dos ramas juntas, la primera es la que ya conocemos como merge que situados en la rama spaghetti podríamos dar el comando:

git merge master

y obtendríamos:

Los parent de este nuevo commit (rosado) serian los últimos de cada rama.

La otra manera de juntar los branch es con rebase, este comando en primera instancia busca el primer commit en común entre los dos branch (commit rojo en nuestro ejemplo), toda la historia antes de este commit ya esta compartida.

Seguidamente git ubica los commit de la actual rama sobre la rama que se le esta haciendo rebase:

git rebase master

Al igual que el merge habría que resolver los conflictos si los hay, ahora el branch spaghetti branch contiene los commit propios y ademas los de el branch master. Si seguidamente se hace rebase de forma invertida git detecta la anterior acción y lo único que hace es pasar al Head el branch master:

A diferencia del merge, terminado el rebase se visualiza como un simple branch :

Diferentes ventajas y desventajas

Merge

  • Preserva la historia del proyecto

  • Las historia con muchos merge puede ser confusa de leer

  • El merge nunca miente

Rebase

  • El proyecto luce mas ágil y limpio

  • La historia limpia que muestra no es tan real, por lo que los commit que se "monta" de un branch a otro son nuevos commit (copias de los originales, que se quedan sin branch y el garbage collector puede eliminar), realmente cambia las historia del proyecto.

  • Algunos comandos avanzados de git le pueden importar la historia real del proyecto

  • Puede que se presenten situaciones confusas como el mismo mensaje en diferentes commits

Rebase es un comando útil si se sabe que se está haciendo y se conocen las consecuencias, pero si tiene dudas es mejor utilizar el merge.