Académique Documents
Professionnel Documents
Culture Documents
de Erice
GUÍA DE
GIT
www.migueldiazrubio.com
1. Bienvenida
por supuesto, seas quien seas, y hagas el tipo de proyectos que hagas.
Como verás a lo largo de esta guía, utilizar Git es algo muy sencillo y que te
1
Aunque siempre que se habla de Git el autor se centra mucho en el
El autor
principios del año 2000 (sí, me perdí el efecto 2000). Desde entonces he
2
Desde el año 2010 mantengo, en la medida en que mi vida personal y
tutoriales sobre el mundo del desarrollo para iOS. Este blog empezó como
estos momentos es una gran aventura que comparto con mi socio y amigo
No te entretengo más y te dejo con esta guía de Git, que hemos preparado
con todo el cariño del mundo, y que esperamos que te ayude a introducir
3
2. ¿Qué es Git?
Linux.
centralizado, sino que lo tiene cada uno de los desarrolladores que utiliza
dicho repositorio.
Instalando Git
git --version
4
Si te encuentras en un sistema operativo Windows, instalar Git es muy
https://git-for-windows.github.io
En mi caso, uso un Mac, por lo que todas las capturas que verás dentro de
5
3. Repositorios
los archivos de una aplicación o proyecto. Una app, una página web, serían
crear un repositorio. Para ello, tengo una carpeta en mi disco local llamada
6
7
Para crear un repositorio para gestionar los archivos que contiene este
git init
directorio app.
8
9
Repositorios remotos
alguien te facilitará la URL de dicho repositorio, que suele ser del tipo:
https://github.com/migueldiazrubio/Workapp.git
es .git.
Pues si quieres trabajar sobre dicho repositorio, tienes que hacer una
10
Esto hará que Git te solicite la contraseña de dicho usuario antes de
11
4. Áreas en Git
pasando por una serie de áreas antes de llegar a estar guardados dentro
industrial se tratase.
Cada una de esas áreas tiene una función específica, y no hay pasos en
segura.
En Git existen principalmente tres áreas por las cuales van a ir pasando
tus cambios:
12
- Área de preparación o staging area: según vas modificando
cambio en el proyecto.
desarrollo de tu proyecto.
git status
13
Una vez hecho esto, puedes ejecutar de nuevo el comando git status y
14
siguiente para añadir todo los archivos del directorio donde estás
ejecutando el comando:
git add .
15
Adicionalmente, puedes establecer el añadido de archivos según un
16
5. Confirmando cambios
Cada vez que hayas finalizado con la creación y/o modificación de archivos
denomina, un commit.
Recuerda que no tienes porque hacer un commit por cada cambio que
17
¿Qué es un commit?
18
aa1b2fb696a831c89c53f787e03d863691d2b671
19
Tu primer commit
siguiente:
20
Committer: MIGUEL DIAZ RUBIO <migueldiazrubio@MacBook-
Pro-de-MIGUEL.local>
You can suppress this message by setting them explicitly. Run the
After doing this, you may fix the identity used for this commit
with:
21
Esto ha ocurrido, porque no tienes configurado en ningún sitio tus datos
como autor, y por este motivo, git ha creado unos por defecto para poder
22
git config --list
credential.helper=osxkeychain
user.email=info@migueldiazrubio.com
core.repositoryformatversion=0
core.filemode=true
core.bare=false
core.logallrefupdates=true
core.ignorecase=true
core.precomposeunicode=true
23
tu segundo commit:
On branch master
24
Esto quiere decir que tu repositorio, área de preparación y área de trabajo
repositorio.
cuenta de que has cometido algún tipo de error en el mismo. Quizás faltan
Si haces un commit y ves que te has equivocado, basta con que añadas
con git add los cambios que faltaran en el área de preparación y hagas un
nuevo commit, pero con el sufijo--amend. Esto hará que los cambios se
incluyan en el último commit realizado, sin tener que crear uno adicional
25
git add fichero_pendiente
recomendación personal:
finalización de la tarea.
Algo que sí debes marcarte como una regla de oro, es que nunca debes
26
o menor cantidad de funcionalidad, y que si usas test (deberías) todos
27
6. Consulta de versiones
28
Eso hará que se muestren todos los commit que se han hecho al
git log -p
commit 679346879387e384bd84c9f404ec4d331c6dbfcf
29
diff --git a/example.json b/example.json
--- a/example.json
+++ b/example.json
@@ -1 +1,2 @@
Mi primer commit
commit 8e0e0c27ebf120a32889f4c452e69fcd1365ef8b
30
new file mode 100644
index 0000000..46b1cdf
--- /dev/null
consola de este tipo, y este es sin duda uno de los motivos que suelen
terminal.
Esto puede parecer sufrir por sufrir, pero nada de eso. Lo que te va a
la siguiente dirección
situaciones donde quieras, o bien consultar cuál era el estado del código
31
en un momento temporal anterior, o bien descartar ciertos cambios que
Si quieres hacer esto mismo pero para todos los archivos, utilizarás:
git checkout -- .
Si quieres descartar todos los cambios de ambas áreas debes utilizar git
32
git clean -df
Por otro lado, otro uso clásico del comando git checkout es para recuperar
commit que hicimos, que en mi caso según git log tiene como
identificador 8e0e0c27ebf120a32889f4c452e69fcd1365ef8b:
Si ahora abres el fichero example.json verás que ahora sólo tiene una línea
33
Además, si ejecutas git log verás que únicamente se muestra el primer
Pues bien, en Git hay algo muy interesante y que permite hacer maravillas,
que son las ramas o branches, y que será algo que verás más adelante en
esta guía. En Git siempre tienes al menos una rama, y la que nos crea un
repositorio por defecto se denomina master. Por otro lado, HEAD tienes
cambios sobre los existentes y juegues un poco con las diferentes áreas y
34
Si ya estás preparado para continuar, ¡vamos adelante!
35
7. Trabajo en equipo
es clonado de forma local por cada uno de los desarrolladores. Cada cierto
36
Para simular este escenario y que puedas experimentar el que denomino
happy flow del proceso (es decir, cuando todo sale bien), pero también
muy fácil, y vas a poder interiorizar de forma rápida todos los conceptos
necesarios.
37
38
39
Una vez creado el repositorio dispones de una URL para el mismo, que
migueldiazrubio/mysampleapp.git.
40
Ahora, vas a indicarle a tu repositorio local, que quieres que se publique
Una vez que tienes asociado tu repositorio local y remoto, vas a subir la
versión del repositorio que tienes en local al servidor de Github. Para ello,
dicho repositorio:
41
Counting objects: 6, done.
To https://github.com/migueldiazrubio/mysampleapp.git
42
A partir de este momento, cualquier persona puede descargarse tu
Ahora al final del todo del fichero añade un nuevo texto “Mi tercer
commit”.
43
Para hacer un commit con este cambio, basta con que te dirijas a la parte
commit:
botón History.
44
Sin embargo, si haces en local un git log verás que únicamente figuran dos.
commit 679346879387e384bd84c9f404ec4d331c6dbfcf
commit 8e0e0c27ebf120a32889f4c452e69fcd1365ef8b
45
Versión con la primera línea de código incluida
pull.
De nuevo estás utilizando los parámetros origin para indicar que quieres
From https://github.com/migueldiazrubio/mysampleapp
46
6793468..38fb48e master -> origin/master
Updating 6793468..38fb48e
Fast-forward
example.json | 1 +
Y si ahora haces un git log verás que ya tienes los 3 commit, tal y como
commit 38fb48e15a271ec1632e675f025c703e6e0f02f7
Update example.json
commit 679346879387e384bd84c9f404ec4d331c6dbfcf
47
Segunda versión del fichero con dos líneas
commit 8e0e0c27ebf120a32889f4c452e69fcd1365ef8b
git remote -v
48
8. Resolución de conflictos
utilizando los comandos git push y git pull. Sin embargo, te has enfrentado
los cambios.
Cuando esto ocurre, tiene que haber una intervención humana, para
indicarle a Git, qué cambios de cada uno de los dos commit quieres
De nuevo vas a simular este escenario, para que puedas entender cómo
proceder en esos casos. Para ello, vas a añadir una cuarta línea en el
49
una cuarta línea distinta mediante un commit en local. Esto generará la
Mi primer commit
Mi segundo commit
Mi tercer commit
Mi primer commit
Mi segundo commit
Mi tercer commit
50
Tienes ante ti un claro conflicto, que tienes que gestionar adecuadamente.
En primer lugar, intenta hacer un pull de los contenidos del remoto a ver
qué ocurre:
From https://github.com/migueldiazrubio/mysampleapp
Auto-merging example.json
51
Como puedes observar, Git ha tratado de hacerlo lo mejor posible, pero
Git:
Mi primer commit
Mi segundo commit
Mi tercer commit
<<<<<<< HEAD
=======
>>>>>>> 0a4d9027cac5948223617e12049b64f80233c6dd
“Cuarta línea desde local” y en remoto en esa misma línea ponía “Cuarta
con el que se ha producido el problema. Para esto, Git utiliza una sintaxis
52
Si quisieras averiguar quién ha publicado y para qué el commit remoto
queda como quinta línea, con el texto “Quinta línea en remoto”. Para ello,
líneas que introduce Git para indicarte los cambios. El fichero final debería
Mi primer commit
Mi segundo commit
Mi tercer commit
53
and have 1 and 1 different commits each, respectively.
Ahora tienes que generar un nuevo commit con la fusión que has hecho
en tu archivo.
git add *
Por último, haz un push al remoto para que ambos repositorios queden
alineados.
On branch master
54
¡Bien! Ya tienes de nuevo tus repositorios perfectamente sincronizados en
mismo.
colorines!
55
9. Ramas y fusiones
56
desarrolladores, que seguirán trabajando en la rama master mientras
tanto.
en otros sistemas como SVN), sino para casi cualquier nuevo cambio a
Esto, que a priori puede parece algo muy complejo, realmente ya lo has
muy similar.
Las ramas, al igual que los commit, puedes dejarlas en tu repositorio local,
aportaciones.
57
Un escenario posible sería tener un proyecto donde tienes la rama
Es importante saber que cuando se genera una rama, los commit que se
preferible en ese caso, hacer esos tres cambios sobre la misma rama.
58
Al final de este capítulo te daré unas pinceladas de las que podrían ser las
repositorio local!
rama deseada
Imagina que quieres crear una nueva rama para la creación de un nuevo
“version-2.0”:
branch sin parámetros, para verificar las ramas que tiene el repositorio en
el que te encuentras.
59
git branch
git branch -r
Y por último, si quieres consultar las ramas tanto locales como remotas:
git branch -a
indicado:
* master
version-2.0
principio?).
60
Switched to branch 'version-2.0'
master
* version-2.0
misma!
haciendo en esta rama, vas a publicar a Github la nueva rama con este
commit:
61
Si te diriges a Github, podrás comprobar que ahora tienes dos ramas
sobre otra
Imagina que ya has acabado con todos los cambios que querías hacer en
master.
Para fusionar los cambios o commit de una rama sobre otra, utilizarás el
62
Por tanto primero cambia a la rama master:
Updating eee6d01..9202eac
Fast-forward
branch.json | 0
Si en este momento ejecutas un git status verás que te indica que tu rama
local tiene un commit más que la rama remota, y te sugiere que publiques
On branch master
63
Your branch is ahead of 'origin/master' by 1 commit.
Pues bien, vamos a hacerle caso y publicar a Github la rama master con
Si ahora haces un git log podrás comprobar cómo tu rama master tiene el
commit 9202eac83df0774d17ef32dfebbd5c98aa7012f2
64
Conocer la procedencia de los commit
de la historia
hayan sido generados en la rama principal, sino que para ello se hayan
Para conocer con este nivel de detalle la procedencia de cada uno de los
git reflog
65
eee6d01 HEAD@{3}: checkout: moving from version-2.0 to
master
66
6793468 HEAD@{14}: reset: moving to HEAD
repositorio
Cuando una rama ha sido fusionada en la rama principal, deja de ser útil
67
error: The branch 'version-2.0' is not an ancestor of your current
HEAD.
If you are sure you want to delete it, run 'git branch -D
version-2.0'.
Si aún así quieres borrarla, tal y como indica el mensaje de error, podemos
envergadura.
68
- master: es la rama de producción de nuestro proyecto, sobre
completamente estable.
“hotfix_inc12100_login_error”.
69
Como ves, una forma muy organizada de trabajar en Git, y que hará que
introducir en tu proyecto.
70
10. Etiquetas o tags
71
Sin embargo, es posible lograr el mismo efecto con un pequeño truco, y es
que puedes utilizar el comando git checkout para generar una rama que
la que partirá.
lanzando.
72
Genera una etiqueta de tu versión actual de la rama master del
¡Así de sencillo!
git tag -l
73
11. Pull request
proyecto en cuestión.
74
El proceso para hacer una pull request es muy sencillo y se puede resumir
dicha rama.
correspondiente.
75
original.
76
12. Trucos y consejos
del sistema.
Gitignore
Este puede que sea el consejo más básico de todos los que siguen, pero
Pues bien, tenemos una forma muy sencilla de indicar a Git qué archivos
77
Para ello, debes crear en el raíz de tu proyecto un fichero con el
exclusión de uno o varios archivos. En cada línea del archivo puedes incluir
.gitignore
**/logs
*.data
mytest.properties
mytest.properties.
78
Todos estos ficheros y directorios no se mostrarán cuando hagas un git
Alias en Git
Si quieres que cuando hagas un git cm se haga un git commit basta con
Algunos alias que puedes crear y que pueden serte realmente de utilidad
son:
79
git config --global alias.last 'log -1 HEAD'
usando Git.
Cherry Pick
Imagina que estas trabajando en una rama y has hecho muchos commit
80
enhorabuena, tenemos un comando que nos permite hacer este pequeño
Su uso es muy sencillo, solo tienes que indicar el identificador del commit
cada uno de los ficheros con conflictos (recuerda buscar los caracteres
<<<<<<< HEAD).
Stash
encuentras trabajando en una rama que has creado para aplicar ciertos
saltar a otra rama para verificar un dato. Sin embargo, cuando ejecutas el
git checkout branch se muestra un error diciendo que tienes cambios sin
81
Pues bien, en este caso, el comando git stash es tu gran amigo, ya que te
git stash
Hecho esto, puedes cambiar de rama para revisar lo que deseas, y tras
confirmadas:
Hooks
trabajo de Git.
(hook) para aplicar la lógica que desees. Por defecto, dentro del
- applypatch-msg.sample
82
- pre-push.sample
- commit-msg.sample
- pre-rebase.sample
- post-update.sample
- prepare-commit-msg.sample
- pre-applypatch.sample
- update.sample
- pre-commit.sample
a un script Python:
#!/usr/bin/env python
Con este mecanismo podemos hacer, por ejemplo, que no se pueda hacer
83
Tenéis muchos ejemplos disponibles en la web de Atlassian dedicada a
https://www.atlassian.com/git/tutorials/git-hooks
84
13. Editores visuales
resultado en el futuro.
ayudar a trabajar mas cómodamente con Git: son los editores visuales.
85
- S o u r c e Tr e e ( G R AT I S ) . D i s p o n i b l e e n h t t p s : / /
www.sourcetreeapp.com
desktop.github.com
86
87
14. Despedida
enhorabuena por el esfuerzo que has hecho. Has llegado al final de esta
Si hay algo de esta guía que creas que podemos mejorar, no dudes en
Git.
¡Hasta pronto!
88