Master Database Migrations with Liquibase and Kotlin Spring Boot

preview_player
Показать описание
In this video, we are going to explore the process of applying database changes using a database migration tool, specifically focusing on Liquibase. We'll dive into a Kotlin Spring Boot microservice that collects event information and uses a PostgreSQL database managed with Liquibase for migrations. I'll walk you through the code and demonstrate how to create tables and columns, manage database migrations, and ensure your service is working as expected.

We'll also discuss the impact of backward-compatible and incompatible changes on the data layer and how to modify the database without causing breaking changes. By analyzing examples of both types of changes, you'll learn how to handle them in a safe and efficient manner. In addition, I'll share some recommended practices for database migrations, such as rolling out schema changes independently from application changes, throttling updates, coordinating database changes with scheduled backups, and waiting before dropping tables or columns.

Throughout the video, I'll be providing step-by-step instructions and showing you how to test your application using HTTP calls. You'll also find all the necessary commands and instructions in the video description, linked to a website containing a detailed tutorial. So join me in this informative and practical guide to enhancing your database migration skills and ensuring the seamless operation of your applications!

Chapters:
00:00 Intro
00:27 The Service (in Kotlin)
01:56 The Database (Postgres)
02:42 Running the service
04:09 Calling the services via HTTP
05:01 Backward compatible DB migrations
05:41 Apply Liquibase migrations
09:12 How to rename a column without breaking your application
10:12 Best Practices for Database Schema Migrations

## Best practices

Here are some best practices for database migrations:

- Rollout schema changes independently from code changes, don’t bundle Schema changes and code changes in the same release. I also prefer to use different release processes to rollout DB changes, for two reasons:
- permissions: privileges required for Schema changes are higher than the ones needed for normal operations
- better design: bundled changes are impossible by design
- Throttle the updates, execute them in small batches as they can affect DB performance or even stop completely the access in case of locks on tables
- Coordinate Database changes with backup schedules, ideally we would like to execute the DB schema changes immediately after a backup
- Wait before dropping, make sure you have enough confidence in the change you just applied. Monitor performance and statistics before and then wait for the next backup and then drop.

WHO AM I:

YOUTUBE GEAR:

MY SOCIAL LINKs:

GET IN TOUCH:

PS: Some of the links in this description are affiliate links that I get a kickback from 😜
Рекомендации по теме
Комментарии
Автор

Great video! Thanks for sharing with the community!

liquibase
Автор

Really great video and very well explained all migration concepts! It would be really great if you can explain how to auto generate the DB schema change-sets when making a change into your schemas.

ElvisPapa
Автор

Interesting video, thanks. I personally would challenge the point of view to allow release / versioning of application/service and data schema. If you are in control of application and data schema and have the possibility I would always make sure application and data schema are locked together and upgraded/migrated (rolled back) at same time. Keep it simple as possible, IT already have a lot of stuff that can go wrong ... Sure if you have multiple instances of services or no possibility of "one shot" upgrade with some downtime, you solution is the best. Maybe before going with independent release cycles/version of data schema and application you can challenge the design of the services/backend data schema. Why data schema is exposed to the service ? Are you not missing some abstraction layer between data layer, backend and exposed service ?

pts