The English version of quarkus.io is the official project site. Translated sites are community supported on a best-effort basis.

Quarkus 1.6 released - AppCDS, Google Cloud Functions, GraalVM 20.1.0 and more...

Summer is here and we are still hard at work improving Quarkus at a rapid pace.

Of course, we improved our existing features, our documentation and fixed bugs but we also delivered some very interesting new features:

  • Integrated generation of AppCDS archives to improve startup time in JVM mode

  • Support for Google Cloud Functions - joining the existing Amazon Lambda and Azure Functions support

  • Reactive IBM Db2 client (the Db2 JDBC driver is coming in 1.7)

  • An Apache Cassandra client

  • WebJars locator extension and Spring @Scheduled support

  • Better tools to troubleshoot your applications

  • Upgrade to GraalVM 20.1.0

A lot of this was made possible by the invaluable feedback and involvement of the community so keep it coming, open issues, start threads on the quarkus-dev list, chat with us on Zulip. We move fast and feedback is directly injected in the next version of Quarkus.

Migration Guide

Eager to migrate your existing applications? Here is our migration guide for 1.6.

What’s new?

Core changes

Fast-jar packaging format

The fast-jar packaging format is maturing. If you haven’t tested it yet on your application, we recommend you give it a try as we will make it the default at some point in the future.

You can test it by adding the following lines to your application.properties:

quarkus.package.type=fast-jar

or passing -Dquarkus.package.type=fast-jar when you build.

AppCDS

Quarkus 1.6 introduces the ability to automatically generate AppCDS as part of the build process.

Essentially if you are using Java 11+, by configuring quarkus.package.create-appcds=true (yes, it’s that simple!) Quarkus will create an AppCDS file that you can then leverage to improve the startup time of the application in JVM mode. The AppCDS file is named app-cds.jsa and is generated in the same directory as the application jar (all types of Quarkus jars are supported).

To make use of it, just run java -jar -XX:SharedArchiveFile=app-cds.jsa myapp.jar from the directory where both the jar and AppCDS file are present (this doesn’t have to necessarily be the original build directory, but the files do need to be in the same directory and the java process must be run from it). Note that this directory requirement isn’t a Quarkus specific limitation, but a JVM requirement stating that the classpaths must be the same when building the AppCDS file and running the application with it. Finally, make sure to use to same JVM version when building and running the application (again this is a JVM limitation).

In the coming days we will have a lot more details to share via a dedicated blog post.

Although this feature is experimental and still needs to be integrated properly with the container-image generation extensions, it nevertheless is fully functional.

CDI development mode endpoint

Quarkus 1.6 introduces some useful endpoints have an overview of your CDI context with /quarkus/arc/beans and /quarkus/arc/observers.

They are described at length in the CDI reference guide.

Maximum file size for request body

It used to be unlimited by default, we now limit it to 10 MB. Of course, you can still configure it via quarkus.http.limits.max-body-size.

扩展

Google Cloud Functions

Quarkus now support serverless on all the major cloud providers with the addition of the support for Google Cloud Functions.

Eager to discover more about it, we have two new guides for you either if you want to develop a simple function or use HTTP.

Reactive IBM Db2 client

We now have reactive SQL clients for MySQL/MariaDB, PostgreSQL and IBM Db2.

Apache Cassandra client

An Apache Cassandra client has joined the Quarkus Platform.

Learn more about how to use Cassandra in your Quarkus applications in the dedicated guide.

WebJars Locator extension

If you are using webjars in your application, we now provide an extension allowing you to drop the version from the webjar path.

More information in our documentation.

Spring @Scheduled support

Our Spring compatibility layer is becoming more and more comprehensive with the addition of the support for Spring’s @Scheduled annotation.

What we support and the current limitations are all described in this new guide.

OpenTracing in the GraphQL extension

Like to trace things? Love GraphQL?

We got you covered as OpenTracing is now enabled in the SmallRye GraphQL extension as soon as the OpenTracing extension is around.

OptaPlanner extension moved out of the core repository

The OptaPlanner extension has been extracted from the Quarkus core repository to the OptaPlanner repository.

In passing, the artifact ids have changed so, if you are using the OptaPlanner extensions in your project, please move to the new ones:

  • org.optaplanner:optaplanner-quarkus

  • org.optaplanner:optaplanner-quarkus-jackson

  • org.optaplanner:optaplanner-quarkus-jsonb

The artifacts are part of the Quarkus Platform so:

  • You can install them directly via https://code.quarkus.io or via the usual add-extension command.

  • It is part of the Platform BOM so you don’t need to define the version.

Native image

GraalVM 20.1.0

We upgraded to GraalVM 20.1.0. While older versions might still work, we recommend an upgrade to this version.

Trust store

The way trust stores are handled by native images has radically changed with GraalVM 19.3.

Our documentation was outdated and not very helpful in this regard, it has been updated.

Troubleshooting

TROUBLESHOOTING.md

Quarkus startup time and runtime performances are always improving and the main reason for that is that we get useful feedback from our community. (Well, and we do benchmarks too.)

When you encounter a performance issue with Quarkus, we often ask for more details and you might not be accustomed with the various tools that would give us useful insights.

Profiling startup or runtime slowness in user applications is made easy with our new TROUBLESHOOTING.md.

Extension dependencies validation

This change will concern you only if you are an extension developer: Quarkus now validates that the deployment and runtime dependencies are consistent in an extension.

If Quarkus warns you about it, check that each runtime dependency has the corresponding deployment artifact in the deployment pom.

Full changelog

You can get the full changelogs of 1.6.0.CR1 and 1.6.0.Final on GitHub.

ADOPTERS.md

To share stories about Quarkus usage, we added an ADOPTERS.md file at the root of the repository.

If you are using Quarkus and would like to be interviewed on our blog or simply added to this file, please contact us and we will be happy to oblige.

贡献者

The Quarkus community is growing and has now 316 contributors. Many many thanks to each and everyone of them.

In particular for the 1.6 release, thanks to Aaron Rogers, Ales Justin, Alex Soto, Alexander Schwartz, Alexey Loubyansky, Andrea Cosentino, Andrej Petras, Andrew Guibert, Andy Damevin, Antonio Goncalves, Aurea Munoz, Luis Barreiro, Bill Burke, Cem Nura, Chris Laprun, Christian Beikov, Clement Escoffier, crissi98, Cuneyt Ozen, David Santos, Dejan Bosanac, Diogo Quintela, Domenico Loiacono, Dominika Vagnerova, Emanuel Alves, Emmanuel Bernard, Falko Modler, Foivos Zakkak, Galder Zamarreño, Garima Monga, Gaétan Collaud, Geoffrey De Smet, George Gastaldi, Georgios Andrianakis, ghokun, Giacomo Margaria, Guillaume Le Floch, Guillaume Nodet, Guillaume Smet, Gunnar Morling, Gwenneg Lepage, Gytis Trikleris, hantsy, Harald Reinmueller, Harsh Madhani, Hugh Lunnon, Ioannis Apostolidis, Ioannis Canellos, Jaikiran Pai, James Perkins, Jan Martiška, Jiří Locker, Jonathan Dowland, Jordi Sola, Jorge Solórzano, Justin Lee, kdnakt, Ken Finnigan, Kevin Viet, Ladislav Thon, Loïc Mathieu, Luka Lodrant, Manyanda Chitimbo, Marcin Czeczko, Mark Borner, Markus Heberling, Martin Kouba, Matej Novotny, Matej Vasek, Max Rydahl Andersen, Michał Górniewski, Michał Szynkiewicz, Moritz Becker, Paul Carter-Brown, Paul Robinson, Paulo Casaes, Pedro Igor, Peter Palaga, Phillip Krüger, Raffael Correia Mendes, Robbie Gemmell, Roberto Cortez, Romain Quinio, Rostislav Svoboda, Sanne Grinovero, Sergey Beryozkin, Sorin I Costea, Stuart Douglas, Ståle Pedersen, Stéphane Épardaud, Thomas Segismont, Timothy Power, Vincent Sevel, Vinícius Ferraz Campos Florentino, Vlastimil Eliáš, Willem Jan Glerum and Yoann Rodière.

Come Join Us

We value your feedback a lot so please report bugs, ask for improvements…​ Let’s build something great together!

If you are a Quarkus user or just curious, don’t be shy and join our welcoming community: