Migration to Quarkus 3.0 is a breeze

Quarkus 3 is out and we encourage our users to upgrade their applications to experience the best Quarkus ever! The team worked hard to deliver a lot of new features and performance improvements. But of course, there are also some breaking changes. The migration guide describes all the important changes in the core extensions.

Nevertheless, there is also some tedious work that needs to be done. Quarkus 3 has updated to the latest Jakarta EE 10 APIs, which include the infamous change of the javax.* to the jakarta.* packages. If your application makes use of any Jakarta API, and there’s a good chance it does (think about JAX-RS, CDI, JPA, etc.), you’ll need to modify your code. Furthermore, if there’s an explicit Jakarta API dependency in the project, you’ll need to update this dependency as well.

Of course, you can migrate the application manually. But since Quarkus embraces the developer joy there is the Quarkus Update Tool to the rescue!

Quarkus Update Tool - TL;DR

  1. Install the Quarkus CLI or make sure a 3+ version is installed

  2. Run quarkus update --stream=3.0

  3. Check the changes made by the tool

  4. Profit!

Quarkus Update Tool - The Full Story

The goal of the update tool is to help developers to migrate an application to Quarkus 3 smoothly. The update process can be triggered from the Quarkus CLI, and directly via Maven or Gradle commands. The tool itself is basically a set of OpenRewrite transformation rules. Most of the rules are defined in the Quarkus Update Recipes project.

What exacty does the update tool do?

  • Updates the Quarkus version

  • Transforms the source code to use the jakarta.* packages

  • Upgrades the Quarkiverse extensions to the versions compatible with Quarkus 3.0

  • Updates the Java EE API dependencies to the Jakarta EE API versions

  • Adjusts some common dependencies (such as Jackson and Hibernate)

  • Transforms the configuration files for some configuration properties (for example quarkus.kubernetes.host to quarkus.kubernetes.ingress.host)

  • Renames some common service providers (for example /META-INF/services/javax.ws.rs.ext.Providers to /META-INF/services/jakarta.ws.rs.ext.Providers)

Maven multi-module projects with standard layout are also supported if the parent project imports a Quarkus Platform BOM.

Let’s get down to business. To run the update:

CLI
quarkus update --stream=3.0
Maven
./mvnw io.quarkus.platform:quarkus-maven-plugin:3.0.3.Final:update -N -Dstream=3.0
Gradle
./gradlew -PquarkusPluginVersion=3.0.3.Final quarkusUpdate --stream=3.0
If using Quarkus CLI then always make sure the latest version is used. The quarkus version command should output version 3+.

Keep in mind that there is no dry-run mode. In other words, once you trigger the update, the changes will be immediately written to the file system. However, you can leverage the source code management tool to see the transformations applied. For example, if using Git then run the update tool and execute the git diff command afterwards to see the changes. And if something went wrong then just use git checkout . to revert the changes.

If your application depends on Hibernate ORM, the dedicated Hibernate ORM 5 to 6 migration guide will come in handy.

That’s it. Your application should be ready now. If there’s something wrong please, ping us on Zulip or file a new issue.

Summary

In this article, we discussed the possibilities of the Quarkus Update Tool that will make your migration to Quarkus 3.0 a breeze. Don’t hesitate and go for it!

The Quarkus Update Tool is not a one-time thing. The plan is to use this tool to provide easy updates for the future versions of Quarkus as well.