SlideShare a Scribd company logo
Database migrations
Flyway and Liquibase
Lars Östling
lars.ostling@jayway.com
@larsostling
Agenda
• Database migrations
• Flyway
• Liquibase
• Conclusions
Back in the day…
• Big up-front design
• Long development cycles
• Scary updates
In an agile world…
• Short iterations
• Continuous integration /
delivery / deployment
• Delivery pipe-lines
• We do it for code …
• … what about the database?
Database migrations with Flyway and Liquibase
The challenge
• Frequent database updates
• Managing multiple sql files
• What has been applied and
what has not?
• Keeping code and database
in sync …
• … throughout all
environments
The solution
Automated database migrations:
• Recreate database from
scratch
• Make it clear at all times what
state a database is in
• Migrate in a deterministic way
from current version of the
database to a newer one
Database migrations with Flyway and Liquibase
What is Flyway?
• Agile database migration framework for Java
• Open Source Apache 2.0 license
• Started in 2010
• Status ‘Adopt’ on thoughtworks technology radar
• http://www.flywaydb.org
Demo
https://github.com/larsostling/
database-migrations-demo
Short recap
• Schema version table
• Convention over configuration
• Sql and java migrations
• Supereasy to setup
Database migrations with Flyway and Liquibase
What is Liquibase?
• Agile database migration framework for Java
• Open Source Apache 2.0 license
• Started in 2006
• http://www.liquibase.org
Demo
https://github.com/larsostling/
database-migrations-demo
Short recap
• Uses structured DSL to
describe database changes
• Databasechangelog table
• Supports rollback
• generateChangeLog
Flyway vs. Liquibase
• SQL vs. XML
• Multiple files vs. single file
• No rollback vs. rollback
• KISS vs. less KISS
Some advice
• Migrate on application startup
• Change sets do not change
• People and processes
Lessons learned
• Stop worrying about database
changes
• Pick a framework and start
using it
Q & A
Thanks!
Lars Östling
lars.ostling@jayway.com
@larsostling

More Related Content

PDF
Database migration with flyway
PPTX
Getting started with agile database migrations for java flywaydb
PPTX
Continuous DB Changes Delivery With Liquibase
PPTX
Database Migrations with Gradle and Liquibase
PPTX
Flyway: The agile database migration framework for Java
PDF
What is DevOps | DevOps Introduction | DevOps Training | DevOps Tutorial | Ed...
Database migration with flyway
Getting started with agile database migrations for java flywaydb
Continuous DB Changes Delivery With Liquibase
Database Migrations with Gradle and Liquibase
Flyway: The agile database migration framework for Java
What is DevOps | DevOps Introduction | DevOps Training | DevOps Tutorial | Ed...

What's hot (20)

PDF
DevOps
PPTX
Apache tomcat
PPTX
Liquibase migration for data bases
PDF
Introduction to docker
PDF
Docker Registry V2
PPTX
Api gateway in microservices
PDF
Scaling DevSecOps Culture for Enterprise
PPTX
Git and GitFlow branching model
PPTX
Docker introduction
PPTX
The Power of Azure DevOps
PDF
Introduction to Docker
PPT
Git workflows
PPTX
GitLab.pptx
PDF
Introduction to Docker Compose
PPTX
Introduction to DevOps
PPTX
Come Fly With Me: Database Migration Patterns with Flyway
PPTX
Azure DevOps in Action
PPTX
Getting started with Jenkins
PPTX
Introduction to Docker - 2017
PDF
[개인 프로젝트] 쿠버네티스를 이용한 개발환경 자동화 구축시스템 - 프로토타입
DevOps
Apache tomcat
Liquibase migration for data bases
Introduction to docker
Docker Registry V2
Api gateway in microservices
Scaling DevSecOps Culture for Enterprise
Git and GitFlow branching model
Docker introduction
The Power of Azure DevOps
Introduction to Docker
Git workflows
GitLab.pptx
Introduction to Docker Compose
Introduction to DevOps
Come Fly With Me: Database Migration Patterns with Flyway
Azure DevOps in Action
Getting started with Jenkins
Introduction to Docker - 2017
[개인 프로젝트] 쿠버네티스를 이용한 개발환경 자동화 구축시스템 - 프로토타입
Ad

Similar to Database migrations with Flyway and Liquibase (20)

PDF
DEVNET-1007 Network Infrastructure as Code with Chef and Cisco
PDF
Network Infrastructure as Code with Chef and Cisco
PDF
DSD-INT 2020 Scripting a Delft-FEWS configuration - Verkade
PPTX
Data Stream Processing for Beginners with Kafka and CDC
PPTX
Training on iOS app development - Samesh Swongamikha & Neetin Sharma
PDF
Alluxio 2.0 & Near Real-time Big Data Platform w/ Spark & Alluxio
PPTX
Security for devs
PPTX
Cool NoSQL on Azure with DocumentDB
PPT
NoSQL_Night
PPTX
Introducing Venice
PDF
David Max SATURN 2018 - Migrating from Oracle to Espresso
PDF
Delivering Changes for Applications and Databases
PDF
Bringing Streaming Data To The Masses: Lowering The “Cost Of Admission” For Y...
PDF
Chicago Microservices Integration Talk
PDF
The future of DevOps: fully left-shifted deployments with version control and...
PPTX
Storage Requirements and Options for Running Spark on Kubernetes
PDF
Road to database automation - Database source control
PDF
Version Control With Subversion
PDF
Streaming Analytics with Spark, Kafka, Cassandra and Akka
PPTX
OpenStack and Windows
DEVNET-1007 Network Infrastructure as Code with Chef and Cisco
Network Infrastructure as Code with Chef and Cisco
DSD-INT 2020 Scripting a Delft-FEWS configuration - Verkade
Data Stream Processing for Beginners with Kafka and CDC
Training on iOS app development - Samesh Swongamikha & Neetin Sharma
Alluxio 2.0 & Near Real-time Big Data Platform w/ Spark & Alluxio
Security for devs
Cool NoSQL on Azure with DocumentDB
NoSQL_Night
Introducing Venice
David Max SATURN 2018 - Migrating from Oracle to Espresso
Delivering Changes for Applications and Databases
Bringing Streaming Data To The Masses: Lowering The “Cost Of Admission” For Y...
Chicago Microservices Integration Talk
The future of DevOps: fully left-shifted deployments with version control and...
Storage Requirements and Options for Running Spark on Kubernetes
Road to database automation - Database source control
Version Control With Subversion
Streaming Analytics with Spark, Kafka, Cassandra and Akka
OpenStack and Windows
Ad

Recently uploaded (20)

PPTX
CHAPTER 12 - CYBER SECURITY AND FUTURE SKILLS (1) (1).pptx
PPTX
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
System and Network Administraation Chapter 3
PPTX
Odoo POS Development Services by CandidRoot Solutions
PPTX
Operating system designcfffgfgggggggvggggggggg
PDF
Design an Analysis of Algorithms II-SECS-1021-03
PPTX
ai tools demonstartion for schools and inter college
PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
AI in Product Development-omnex systems
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PDF
2025 Textile ERP Trends: SAP, Odoo & Oracle
PPTX
L1 - Introduction to python Backend.pptx
PPTX
Introduction to Artificial Intelligence
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PDF
System and Network Administration Chapter 2
CHAPTER 12 - CYBER SECURITY AND FUTURE SKILLS (1) (1).pptx
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
How to Migrate SBCGlobal Email to Yahoo Easily
How Creative Agencies Leverage Project Management Software.pdf
System and Network Administraation Chapter 3
Odoo POS Development Services by CandidRoot Solutions
Operating system designcfffgfgggggggvggggggggg
Design an Analysis of Algorithms II-SECS-1021-03
ai tools demonstartion for schools and inter college
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
Wondershare Filmora 15 Crack With Activation Key [2025
AI in Product Development-omnex systems
Which alternative to Crystal Reports is best for small or large businesses.pdf
Odoo Companies in India – Driving Business Transformation.pdf
2025 Textile ERP Trends: SAP, Odoo & Oracle
L1 - Introduction to python Backend.pptx
Introduction to Artificial Intelligence
Internet Downloader Manager (IDM) Crack 6.42 Build 41
System and Network Administration Chapter 2

Database migrations with Flyway and Liquibase