Git

Git


Git( anuncios de adwords "guit"

​) es un software dediseñado por, pensando en la eficiencia y la fiabilidad del mantenimiento de versiones de aplicaciones cuando éstas tienen un enorme número de ficheros de. Su propósito es llevar registro de los cambios en ficheros de computadora y regular el trabajo que múltiples personas efectúan sobre ficheros compartidos.

Al principio, Git se pensó como un motor de bajo nivel sobre el que otros pudiesen escribir la interfaz de usuario ocomoo.

​Sin embargo, Git se ha convertido desde ese momento en un sistema de control de versiones con funcionalidad plena.

​Hay ciertos proyectos de mucha relevancia que ya utilizan Git, en particular, el conjunto dedel.

ElGit está hoy en día (2009) supervisado por Junio Hamano, quien recibe contribuciones al código de alrededor de doscientos ochenta programadores. En cuanto a derechos de autor Git es undistribuible bajo los términos de la versión 2 de la.

Características

El diseño de Git se basó eny en.

​ Originalmente fue diseñado como un motor de sistema de control de versiones de bajo nivel sobre el que otros podrían codificar interfaces frontales, semejantes comoo.

​ Desde ese entonces hasta el momento el núcleo del proyecto Git se ha vuelto un sistema de control de versiones completo, aprovechable en forma directa.

buscaba un sistema distribuido que pudiese usar en forma semejante a BitKeeper, pero ninguno de los sistemas bajo software libre disponibles cumplía con sus requerimientos, singularmente en lo que se refiere a desempeño. El diseño de Git mantiene una gran cantidad de código distribuida y gestionada por bastante gente, que incide en numerosos detalles de desempeño, y de la necesidad de velocidad en una primera implementación.

Entre las características más relevantes se encuentran:

  • Fuerte apoyo al desarrollo no lineal, por ende rapidez en la gestión de ramas y mezclado de diferentes versiones. Git incluye herramientas específicas para navegar y visualizar un historial de desarrollo no lineal. Una presunción esencial en Git, es que un cambio será fusionado mucho más frecuentemente de lo que se escribe originalmente, conforme se pasa entre múltiples programadores que lo examinan.
  • Gestión distribuida. Del mismo modo que,,,,y, Git le da a cada programador una copia local del historial del desarrollo entero, y los cambios se propagan entre loslocales. Los cambios se importan como ramas adicionales y pueden ser fusionados en exactamente la misma forma que se hace con la rama local.
  • Los almacenes de información pueden publicarse por,,o mediante un protocolo nativo, ya sea a través de una conexión TCP/IP simple o a través de cifrado. Git también puede emular servidores, lo que habilita el uso de clientes CVS pre-existentes y módulos IDE para CVS pre-existentes en el acceso de repositorios Git.
  • Los repositorios Subversion y svk se pueden utilizar de manera directa con git-svn.
  • Gestión eficaz de proyectos grandes, dada la rapidez de gestión de diferencias entre ficheros, entre otras muchas mejoras de optimización de velocidad de ejecución.
  • Todas las versiones previas a un cambio determinado, implican la notificación de un cambio siguiente en cualquiera de ellas a ese cambio (denominado autenticación criptográfica de historial). Esto existía en.
  • Resulta algo más caro trabajar con archivos específicos en frente de proyectos, eso diferencia el trabajo frente a CVS, que trabaja con base en cambios de fichero, pero mejora el trabajo con afectaciones de código que concurren en operaciones similares en múltiples archivos.
  • Los renombrados se trabajan basándose en semejanzas entre ficheros, además de nombres de archivos, mas no se hacen marcas explícitas de cambios de nombre con base en supuestos nombres únicos de nodos de sistema de archivos, lo que evita posibles y desastrosas coincidencias de archivos diferentes en un único nombre.
  • Realmacenamiento periódico en paquetes (archivos). Esto es parcialmente eficiente para escritura de cambios y relativamente ineficiente para lectura si el reempaquetado (con base en diferencias) no ocurre cada cierto tiempo.

Órdenes básicas

Git ciclo de vida de archivos git

Esto crea un subdirectorio nuevo llamado .git, el cual contiene todos y cada uno de los ficheros necesarios del repositorio – un esqueleto de un repositorio de Git. Todavía no hay nada en tu proyecto que esté bajo seguimiento.

Descarga los cambios realizados en el repositorio remoto.

  • git merge

    <nombre_rama>

    :

Impacta en la rama en la que te encuentras parado, los cambios realizados en la rama “nombre_rama”.

Unifica los comandos

fetchy

mergeen un único comando.

  • git commit -am "<mensaje>":

Confirma los cambios realizados. El “mensaje” generalmente se usa para asociar al

commituna breve descripción de los cambios realizados.

  • git push origin

    <nombre_rama>

    :

Sube la rama “nombre_rama” al servidor remoto.

Muestra el estado actual de la rama, como los cambios que hay sin commitear.

  • git add

    <nombre_archivo>

    :

Comienza a trackear el fichero “nombre_archivo”.

  • git checkout -b

    <nombre_rama_nueva>

    :

Crea una rama desde la que te encuentres parado con el nombre “nombre_rama_nueva”, y después brinca sobre la rama nueva, con lo que quedas parado en esta última.

  • git checkout -t origin/

    <nombre_rama>

    :

Si existe una rama recóndita de nombre “nombre_rama”, al ejecutar este comando se crea una rama local con el nombre “nombre_rama” para hacer un seguimiento de la rama remota con el mismo nombre.

Lista todas las ramas locales.

Lista todas las ramas locales y recónditas.

  • git branch -d

    <nombre_rama>

    :

Elimina la rama local con el nombre “nombre_rama”.

  • git push origin

    <nombre_rama>

    :

Commitea los cambios desde el branch local origin al branch “nombre_rama”.

Actualiza tu repositorio recóndito en caso que algún otro desarrollador haya eliminado alguna rama remota.

Elimina los cambios efectuados que aún no se hayan hecho

commit.

  • git revert

    <hash_commit>

    :

Revierte el

commitrealizado, identificado por el “hash_commit”.

Flujo de trabajo

Git plantea una gran libertad en la forma de trabajar en torno a un proyecto. Sin embargo, para coordinar el trabajo de un conjunto de personas en torno a un proyecto es preciso convenir como se va a trabajar con Git. A estos acuerdos se les llama

flujo de trabajo

​ Un flujo de trabajo de Git es una fórmula o bien una recomendación sobre el empleo de Git para efectuar trabajo de forma uniforme y productiva.

​Los flujos de trabajo más populares son git-flow, GitHub-flow, GitLab Flow y One Flow.

Creado en 2010 por Vincent Driessen.

​ Es el flujo de trabajo más conocido. Está concebido para aquellos proyectos que tienen entregables y ciclos de desarrollo bien definidos.

​Está basado en 2 grandes ramas con infinito tiempo de vida (ramas master y develop) y múltiples ramas de apoyo, unas orientadas al desarrollo de nuevas funcionalidades (ramas feature-*), otras al arreglo de errores (hotfix-*) y otras orientadas a la preparación de nuevas versiones de producción (ramas release-*). La herramienta gitflowfacilita la automatización de las tareas implicadas en este flujo de trabajo

Master

Es la rama principal. Contiene el repositorio que se encuentra publicado en producción, por lo que debe estar siempre y en toda circunstancia estable.

Development

Es una rama sacada de

Master. Es la rama de integración, todas y cada una de las nuevas funcionalidades se deben integrar en esta rama. Luego que se realice la integración y se corrijan los errores (en el caso de haber alguno), o sea que la rama se encuentre estable, se puede hacer un merge de development sobre la rama

Master.

Features

Cada nueva funcionalidad se debe efectuar en una rama nueva, específica para esa funcionalidad. Estas se deben sacar de

Development. Una vez que la funcionalidad esté desarrollada, se hace un merge de la rama sobre

Development, donde se integrará con las demás funcionalidades.

Hotfix

Sonque brotan en producción, con lo que se deben reparar y publicar de forma urgente. Es por esta razón, que son ramas sacadas de

Master. Una vez corregido el error, se debe hacer una unificación de la rama sobre

Master. Al final, a fin de que no quede desactualizada, se debe realizar la unificación de

Mastersobre

Development.

Release

Las ramas de release apoyan la preparación de nuevas versiones de producción. Para ellos se arreglan muchos errores menores y se preparan adecuadamente los metadatos. Se suelen original de la rama develop y deben fusionarse en las ramas master y develop.

GitHub-Flow

Creado en 2011 por GitHub

​ y es la manera de trabajo sugerida por las funcionalidades propias de GitHub . Está centrado en un modelo de desarrollo iterativo y de despliegue constante. Está basado en cuatro principios:

  • Todo lo que está en la rama master está listo para ser puesto en producción
  • Para trabajar en algo nuevo, debes crear una nueva rama desde la rama master con un nombre gráfico. El trabajo se irá integrando sobre esa rama en local y regularmente también a esa rama en el servidor
  • Cuando se necesite ayuda o bien información o bien cuando pensamos que la rama está lista para integrarla en la rama master, se debe abrir una pull request (solicitud de integración de cambios).
  • Alguien debe comprobar y visar los cambios para fusionarlos con la rama master
  • Los cambios integrados se pueden poner en producción.

GitHub intenta facilitar la gestión de ramas, trabajando de manera directa sobre la rama master y produciendo integrando las diferentes features de forma directa a esta rama

GitLab Flow

Creado en dos mil catorce por Gitlab.

​Es una suerte de extensión de GitHub Flow acompañado de un conjunto de pautas y mejores prácticas que apuntan a estandarizar aún más el proceso. Del mismo modo que GitHub Flow propone el empleo de ramas de funcionalidad (feature) que se originan a partir de la rama master y que al finalizarse se mezclan con la rama master. Además introduce otros 3 géneros de ramas:

  • Ramas de entorno. Por servirnos de un ejemplo pre-production production. Se crean desde la rama master cuando estamos listos para implementar nuestra aplicación. Si hay un fallo crítico lo podemos reparar en un rama y después entremezclarla en la rama de entorno.
  • Ramas de versión. Por poner un ejemplo quince-stable dieciseis-stable. El flujo puede incluir ramas de versión caso de que el software requiera lanzamientos frecuentes.

Creado en 2015 por Adam Ruka. desarrollo de microsites él cada nueva versión de producción está basada en la versión previa de producción. La mayor diferencia entre One Flow y Git Flow es que One Flow no tiene rama de desarrollo.

Software que los usa como base

Git se ha usado como software base sobre el que el que se han desarrollado otros proyectos

  • . Aplicación web que permite la revisión de código en equipo para la aprobación o bien rechazo de modificaciones. Consiste de un repositorio Git que actúa como mediador entre los gits de los desarrolladores y el repositorio Git que utiliza la. Los desarrolladores en vez de mandar el código al sistema de integración continua lo envían al repositorio Gerrit donde se han establecido político.

  • Las plataformas deson plataformas web que ofrecen servicios que dejan el desarrollo colaborativo de software. Uno de los servicios básicos ofrecidos es crear poder crear repositorio de software en un sistema deconcreto. El sistema de control de versiones más utilizado es Git. crear una pagina web de estos servicios son,y. Se han desarrollado múltiples soluciones que dejan crear automáticamente forjas software como por ejemplo,,o las versiones de plataformas ofrecidas por GitHub (GitHub Enterprise), Gitlab (GitLab CE y GitLab EE) y Bitbucket.

  • . Es un usuario de código abierto que permite utilizar repositorios Git como, dejando la sincronización de archivos y colaboración en la nube de forma afín a. Los repositorios Git pueden estar en una máquina Linux, generalmente creados con la aplicacióno en repositorios git alojados en la nube utilizando servicios como,,o.

  • . Herramienta de git que permite hacer cifrado de forma absolutamente transparente. Cuando se hace un git push los archivos marcados para cifrar se cifren automáticamenteno. Análogamente se hará cuando se hace un git pull. Así podemos tener un repositorio que tenga una parte de sus ficheros cifrados y otra parte sin cifrar. El cifrado se puede efectuar con claves de(con) o.

  • Herramientas, como gitflow, que facilitan la automatización de las tareas implicadas en cierto/s flujo/s de trabajo.

Véase también

Referencias

Enlaces externos

Report Page