Install Liquibase with Spring Boot
Last updated: November 18, 2025
The purpose of this tutorial is to guide you through the process of using Liquibase as part of your Spring Boot workflow.
The Liquibase Spring Boot integration ensures the application's database is updated along with the application code by embedding your changelog files in your application and automatically running Liquibase update as part of your application startup.
Before you begin
Ensure you have Java Development Kit (JDK 17+)
If you do not already have a Spring Boot application, you can create one with the Spring Initializer.
Procedure
Add the Liquibase dependency
If you did not already add the Liquibase dependency when creating your project, you can add it manually by adding com.liquibase:liquibase-commercial as a dependency to your project.
Be sure to replace your_version with the Liquibase version you want to download. For example, liquibase-secure-5.0.3.
Apply your Liquibase Secure license key
Using a Secrets Management tool like Hashicorp Vault or AWS Secrets Manager is best to keep Liquibase license keys secure.
There are several ways to apply the Liquibase Secure license key:
Add the Liquibase Secure license key to your Spring Boot application.properties file and save it.
For example:
spring.liquibase.license-key=aei76ou32thp785463214
Pass the Liquibase Secure license key as a parameter in the command line during runtime:
liquibase --license-key=[paste the Liquibase Secure license key] [command]
For example:
liquibase --license-key=aei76ou32thp785463214 update
Set the Liquibase Secure license key as an environment variable in the command line.
On Windows:
set LIQUIBASE_LICENSE_KEY=aei76ou32thp785463214
On Linux/macOS:
export LIQUIBASE_LICENSE_KEY=aei76ou32thp785463214
Set the Liquibase Secure license key with the JAVA_OPTS Environment Variable in the command line:
JAVA_OPTS="Dliquibase.licenseKey=<enter license key here>"
Pass the Liquibase Secure license key while using a Docker container. Docker allows the use of --env in the command.
docker run --env LIQUIBASE_LICENSE_KEY=<enter license key here>... \
-it liquibase/liquibase-secure:latest sh
If you use Maven, include the Liquibase Secure license key in the <properties> section of your pom.xml file:
<liquibaseLicenseKey>key-goes-here</liquibaseLicenseKey/>
For example:
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-commercial-maven-plugin</artifactId>
<version>0-SNAPSHOT</version>
<configuration>
<changelogFile>com/example/changelog_v4.6.xml</changelogFile>
<liquibaseLicenseKey>key-goes-here</liquibaseLicenseKey>
</configuration>
</plugin>
Note: In older versions of Liquibase, you must use the syntax <liquibaseProLicenseKey> instead of <liquibaseLicenseKey>.
You can directly embed your Liquibase Secure license key (myProLicenseKey) in a custom Java application by following these steps:
In your Maven
pom.xmlfile, point toliquibase-commercial.jaras a dependency:<dependency> <groupId>org.liquibase</groupId> <artifactId>liquibase-commercial</artifactId> <version>4.33.0</version> </dependency>In your custom Java file, import the following:
import com.datical.liquibase.ext.config.LiquibaseLabsConfiguration;In your custom Java file, call on the
LiquibaseLabsConfigurationclass. For example, to specify your license key so that you can run the Liquibase Secureupdate-one-changesetcommand:Scope.child(LiquibaseLabsConfiguration.LICENSE_KEY.getKey(), "myProLicenseKey", () -> new CommandScope(UpdateOneChangeSetSqlCommandStep.COMMAND_NAME) .addArgumentValue(DbUrlConnectionArgumentsCommandStep.DATABASE_ARG, liquibase.getDatabase()) .addArgumentValue(DatabaseChangelogCommandStep.CHANGELOG_FILE_ARG, "/db_schema/changelog.xml") .addArgumentValue(UpdateOneChangeSetCommandStep.CHANGESET_AUTHOR_ARG, "fl") .addArgumentValue(UpdateOneChangeSetCommandStep.CHANGESET_ID_ARG, "1") .addArgumentValue(UpdateOneChangeSetCommandStep.CHANGESET_PATH_ARG, "/db_schema/changelog.xml") .execute() );
For information on running Liquibase commands in Java files, see liquibase.command.CommandScope.
If you use Azure DevOps and pass your license key as an environment variable, you can set the value of LIQUIBASE_LICENSE_KEY in your Azure DevOps pipeline setting file:
script: |
echo "Running Policy Checks"
liquibase checks run --changeLogFile=mysqlChangelog.xml
displayName: 'Run Policy Checks'
env:
LIQUIBASE_LICENSE_KEY: $(LiquibaseKey)
In this example, LiquibaseKey is the name of the Azure DevOps project variable whose value is the license key.
Add a Changelog File
Create a changelog file in your project. By default, The Spring Boot Liquibase integration looks for a file named db.changelog-master.xml in the src/main/resources/db/changelog directory.
Start your application
When you start your application with mvn spring-boot:run or gradle bootRun, Liquibase will automatically run the changelog file and update your database.
Try it now, and you should see the table test_table created in your database.