SlideShare una empresa de Scribd logo
1 de 38
Descargar para leer sin conexión
An Evening with…

Arkho Innova Meetup Series
• Un espacio para compartir experiencias
y conocimiento
• Un espacio para hacer relaciones entre
equipos con intereses afines
• Un espacio para pasarla bien
Gracias por su asistencia!!!
Overview
• ¿Qué es Liquibase?
• Objetivos y funcionalidades principales
• Equipo de desarrollo trabajando con Liquibase y
su proceso de adaptación.
• Visión del equipo una vez adoptada la tecnología.
• Ejemplo 1
• Ejemplo 2
• Best Practices
• Resumen
¿Qué es Liquibase?
Gestión de cambios en
una base de datos
Código
¿Qué ocurre cuando hay
cambios en la base de datos?
Error SQL..?
Con este cambio
quedo como Rey
Me mandan el script SQL
con los cambios please
Database changes
Primeros pasos
Liquibase desde línea de comando
• Bajar liquibase desde 

http://www.liquibase.org/download/
index.html
• Extraer Zip e instalar liquibase para
ejecutarlo por línea de comandos.



$ liquibase —help
Liquibase desde Maven
• Bajar liquibase desde 

http://www.liquibase.org/download/index.html
• Extraer Zip e instalar liquibase para ejecutarlo por línea de comandos.



$ mvn liquibase:<comando>
Archivo changelog.xml
• Bitácora de cambios
• Id del cambio
• Autor del cambio
• Cambio realizado
• Otros parámetros
Ejemplo changelog.xml
Parámetros changelog + usados
id ID del cambio. Se recomienda utilizar YYYYMMDD+num
author Nombre de quien realiza el cambio.
dbms Motor de base de datos soportado que se está utilizando.
runAlways Ejecuta este cambio siempre. Incluso si ya fue ejecutado previamente.
runOnChange Ejecuta el cambio la primera vez y luego cada vez que detecte que ese valor fue modificado.
failOnError Ante un error detiene la ejecución del changelog y arroja un error.
Rollback
Equipo de desarrollo y el cambio de
paradigma
Nuestra experiencia
• Tiempo de comprensión
• Tiempo de adaptación
• Resistencia al cambio
• Solución de conflictos
• Felicidad
Tiempo de comprensión
• Lo que demora el equipo en comprender el
funcionamiento de la herramienta.
• Curva de aprendizaje logarítmica
Tiempo de adaptación
• El equipo se debe acostumbrar a trabajar con la herramienta.
• Resistencia al cambio
Resistencia al cambio
• Cuesta no realizar las modificaciones
directamente en la base de datos.
• Se acostumbra a cambiar algo hasta
que funcione sin hacer un análisis
previo real de lo que se requiere.
Solución de conflictos
• Cambié algo en la base de datos, luego hice el cambio en mi
changelog.
• Me arroja error. ¿Qué hago?
Felicidad
• El equipo se compenetra en el
uso de la herramienta.
• Los deployments luego de un
cambio son transparentes
• Levantar un ambiente se hace
cada vez más fácil.
Visión actual del equipo
Ejemplo 1
Primer encuentro con liquibase
Ejemplo 1
• Liquibase por línea de comandos
• Generar chagelog inicial
• Generar modificaciones en la base de datos
Ejemplo 2
Primer encuentro con liquibase
Ejemplo 2
• Iniciar proyecto con Liquibase desde cero.
• Liquibase y Maven
• Liquibase como herramienta de integración continua.
Changelogs por releases
• Ayuda a mantener ordenado el
versionamiento (legibilidad)
• Fácil encontrar cambios hechos
en alguna etapa del proyecto
ChangeSets eficientes
• Ayuda a mantener ordenadas
las modificaciones dentro del
changelog (legibilidad)
• Fácil estructuración de
rollbacks
Uso eficiente de id y comment
• Mejora la solución de
problemas
• Aclara la lectura de los
cambios para todo el equipo
Resumen
Beneficios
• Se mantiene un historial de todos los cambios realizados en la base
de datos.
• Se hace más eficiente el trabajo en equipo.
• Levantar un ambiente ya sea local o remoto se simplifica de manera
enorme.
• Disminuye la cantidad de involucrados en un proceso de deploy.
• Importante apoyo en el proceso de migración de una base de datos a
otra.
Desventajas
Desventajas liquibase
Código fuente
• https://github.com/harenas/meetup-liquibase-ejemplo-1
• https://github.com/harenas/meetup-liquibase-ejemplo-2
An Evening with…

Arkho Innova Meetup Series

Más contenido relacionado

Similar a An Evening with Arkho Innova Meetup (20)

introduccion-a-netbeans
introduccion-a-netbeansintroduccion-a-netbeans
introduccion-a-netbeans
 
1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans
 
1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans
 
Introduccion a netbeans
Introduccion a netbeansIntroduccion a netbeans
Introduccion a netbeans
 
Manual de Netbeans
Manual de NetbeansManual de Netbeans
Manual de Netbeans
 
1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans
 
Tutorial neatbeans(3)
Tutorial neatbeans(3)Tutorial neatbeans(3)
Tutorial neatbeans(3)
 
Tutorial neatbeans(3)
Tutorial neatbeans(3)Tutorial neatbeans(3)
Tutorial neatbeans(3)
 
Netbeans manual
Netbeans manual Netbeans manual
Netbeans manual
 
1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans1 introduccioi81n-a-netbeans
1 introduccioi81n-a-netbeans
 
manual 1
manual 1manual 1
manual 1
 
MANUAL
MANUAL MANUAL
MANUAL
 
Manualnetbeans2 141006101152-conversion-gate02jjj
Manualnetbeans2 141006101152-conversion-gate02jjjManualnetbeans2 141006101152-conversion-gate02jjj
Manualnetbeans2 141006101152-conversion-gate02jjj
 
MANUAL NETBEANS
MANUAL NETBEANSMANUAL NETBEANS
MANUAL NETBEANS
 
MANUAL DE NETBEANS
 MANUAL DE NETBEANS MANUAL DE NETBEANS
MANUAL DE NETBEANS
 
NEAT1
NEAT1NEAT1
NEAT1
 
Manualnetbeans2 141
Manualnetbeans2 141Manualnetbeans2 141
Manualnetbeans2 141
 
Netbean
Netbean Netbean
Netbean
 
Manual netbeans_2
Manual netbeans_2Manual netbeans_2
Manual netbeans_2
 
manual de netbeans
manual de netbeansmanual de netbeans
manual de netbeans
 

Más de Arkhotech

An Evening with Agile lean design_thinking
An Evening with Agile lean design_thinkingAn Evening with Agile lean design_thinking
An Evening with Agile lean design_thinkingArkhotech
 
An Evening with Meetup microservices-s2
An Evening with Meetup microservices-s2An Evening with Meetup microservices-s2
An Evening with Meetup microservices-s2Arkhotech
 
An evening with...Rust
An evening with...RustAn evening with...Rust
An evening with...RustArkhotech
 
An Evening with... Go Lang
An Evening with... Go LangAn Evening with... Go Lang
An Evening with... Go LangArkhotech
 
An evening with... Docker
An evening with... DockerAn evening with... Docker
An evening with... DockerArkhotech
 
An evening with "Rework" - Reinventando nuestra forma de trabajar
An evening with "Rework" - Reinventando nuestra forma de trabajarAn evening with "Rework" - Reinventando nuestra forma de trabajar
An evening with "Rework" - Reinventando nuestra forma de trabajarArkhotech
 
An evening with... Microservices - Session 1
An evening with... Microservices - Session 1An evening with... Microservices - Session 1
An evening with... Microservices - Session 1Arkhotech
 
An evening with... Scrum
An evening with... ScrumAn evening with... Scrum
An evening with... ScrumArkhotech
 
An evening with... DevOps
An evening with... DevOpsAn evening with... DevOps
An evening with... DevOpsArkhotech
 
An evening with ... Ionic Framework Meetup
An evening with ... Ionic Framework Meetup An evening with ... Ionic Framework Meetup
An evening with ... Ionic Framework Meetup Arkhotech
 
An evening with... BPM redhat Meetup
An evening with... BPM redhat MeetupAn evening with... BPM redhat Meetup
An evening with... BPM redhat MeetupArkhotech
 
An evening with... Continuous Integration and Bamboo intro Meetup
An evening with... Continuous Integration and Bamboo intro MeetupAn evening with... Continuous Integration and Bamboo intro Meetup
An evening with... Continuous Integration and Bamboo intro MeetupArkhotech
 
An evening with... Agile Metrics Meetup
An evening with... Agile Metrics MeetupAn evening with... Agile Metrics Meetup
An evening with... Agile Metrics MeetupArkhotech
 
An evening with... Apache hadoop Meetup
An evening with...  Apache hadoop MeetupAn evening with...  Apache hadoop Meetup
An evening with... Apache hadoop MeetupArkhotech
 
An evening with... Polymer Intro Meetup
An evening with... Polymer Intro MeetupAn evening with... Polymer Intro Meetup
An evening with... Polymer Intro MeetupArkhotech
 
An evening with... Oracle Endeca Guided Search & Experience Manager Meetup
An evening with... Oracle Endeca Guided Search & Experience Manager MeetupAn evening with... Oracle Endeca Guided Search & Experience Manager Meetup
An evening with... Oracle Endeca Guided Search & Experience Manager MeetupArkhotech
 
An evening with... No SQL Meetup
An evening with... No SQL MeetupAn evening with... No SQL Meetup
An evening with... No SQL MeetupArkhotech
 

Más de Arkhotech (17)

An Evening with Agile lean design_thinking
An Evening with Agile lean design_thinkingAn Evening with Agile lean design_thinking
An Evening with Agile lean design_thinking
 
An Evening with Meetup microservices-s2
An Evening with Meetup microservices-s2An Evening with Meetup microservices-s2
An Evening with Meetup microservices-s2
 
An evening with...Rust
An evening with...RustAn evening with...Rust
An evening with...Rust
 
An Evening with... Go Lang
An Evening with... Go LangAn Evening with... Go Lang
An Evening with... Go Lang
 
An evening with... Docker
An evening with... DockerAn evening with... Docker
An evening with... Docker
 
An evening with "Rework" - Reinventando nuestra forma de trabajar
An evening with "Rework" - Reinventando nuestra forma de trabajarAn evening with "Rework" - Reinventando nuestra forma de trabajar
An evening with "Rework" - Reinventando nuestra forma de trabajar
 
An evening with... Microservices - Session 1
An evening with... Microservices - Session 1An evening with... Microservices - Session 1
An evening with... Microservices - Session 1
 
An evening with... Scrum
An evening with... ScrumAn evening with... Scrum
An evening with... Scrum
 
An evening with... DevOps
An evening with... DevOpsAn evening with... DevOps
An evening with... DevOps
 
An evening with ... Ionic Framework Meetup
An evening with ... Ionic Framework Meetup An evening with ... Ionic Framework Meetup
An evening with ... Ionic Framework Meetup
 
An evening with... BPM redhat Meetup
An evening with... BPM redhat MeetupAn evening with... BPM redhat Meetup
An evening with... BPM redhat Meetup
 
An evening with... Continuous Integration and Bamboo intro Meetup
An evening with... Continuous Integration and Bamboo intro MeetupAn evening with... Continuous Integration and Bamboo intro Meetup
An evening with... Continuous Integration and Bamboo intro Meetup
 
An evening with... Agile Metrics Meetup
An evening with... Agile Metrics MeetupAn evening with... Agile Metrics Meetup
An evening with... Agile Metrics Meetup
 
An evening with... Apache hadoop Meetup
An evening with...  Apache hadoop MeetupAn evening with...  Apache hadoop Meetup
An evening with... Apache hadoop Meetup
 
An evening with... Polymer Intro Meetup
An evening with... Polymer Intro MeetupAn evening with... Polymer Intro Meetup
An evening with... Polymer Intro Meetup
 
An evening with... Oracle Endeca Guided Search & Experience Manager Meetup
An evening with... Oracle Endeca Guided Search & Experience Manager MeetupAn evening with... Oracle Endeca Guided Search & Experience Manager Meetup
An evening with... Oracle Endeca Guided Search & Experience Manager Meetup
 
An evening with... No SQL Meetup
An evening with... No SQL MeetupAn evening with... No SQL Meetup
An evening with... No SQL Meetup
 

An Evening with Arkho Innova Meetup