Contact Us About Sponsorship

Questions about Micronaut Foundation sponsorship?

Please complete this form, and we’ll follow up with you shortly.

Micronaut Framework 4.0.0 Released!

by Sergio Del Amo Caballero Tags:

The Micronaut Foundation is excited to announce the general availability (GA) release of Micronaut framework 4!

What’s New in Micronaut Framework 4?

Language Baselines

Micronaut framework 4 updates to Apache Groovy 4, Kotlin 1.8 and sets the Java baseline to 17.

Kotlin 

If you use Kotlin, you can build your Micronaut applications with KSP (Kotlin Symbol Processing). While KSP support is only available for Gradle, Kapt is still available for Gradle and Maven. 

In addition, Micronaut Kotlin updates to Ktor 2

GraalVM 

Micronaut framework 4 supports the latest GraalVM release and shifted to runtime initialisation for GraalVM to ensure consistency in behavior between JIT and Native applications.

Additionally, the required metadata for GraalVM now resides on the GraalVM Reachability Metadata Repository and both Micronaut Gradle and Maven plugins use it by default.

The Micronaut Foundation continues to invest to bring you the best GraalVM integration.  As an example, we added JUnit 5 native tests across the Framework infrastructure. 

Gradle 8

If you use Gradle to build your Micronaut applications, Micronaut framework 4 now requires Gradle 8

Expression Language

Micronaut framework 4 introduces an expression language which allows you to put expressions in annotations. Micronaut expression language is designed to be secure by default. It is not possible to compile expressions at runtime from untrusted user input. All expressions are evaluated at compilation time, are type-checked, and they are reflection free making them GraalVM ready. 

For example, you can use expressions with Micronaut Security @Secured annotation.

@Secured("#{ user?.attributes?.get('email') = 'sherlock@micronaut.example' }")

Virtual Threads (Loom)

Micronaut framework 4 detects virtual thread support (available since Java 19 as a preview feature), and uses it for the executor named BLOCKING if available. If the Java version does not support virtual threads, the Framework aliases this executor to IO. 

You can replace @ExecutesOn(IO) with @Executes(BLOCKING) to get ready. 

HTTP Improvements

Rewritten HTTP layer

The HTTP layer has been rewritten to improve performance and reduce the presence of reactive stack frames if reactive is not used (such as with Virtual threads).

Experimental Support for HTTP/3 and io_uring

Micronaut framework 4 includes experimental support for HTTP/3  and experimental support for io_uring via the Netty incubator project.

Annotation-Based Filters

Micronaut framework 4 adds annotation-based filters; an additional way to write server and client filters. You can write filters without writing any line of reactive code. When used with Virtual Threads, annotation-based filters allow the Framework to optimize throughput and remove unnecessary reactive stack frames, improving performance.

@ServerFilter("/hello/**")
class TraceFilter {
    @Inject TraceService traceService;
    @RequestFilter
    @ExecuteOn(TaskExecutors.BLOCKING)
    public void filterRequest(HttpRequest<?> request) {
          traceService.trace(request);
    }
    @ResponseFilter
    public void filterResponse(MutableHttpResponse<?> res) {
        res.getHeaders().add("X-Trace-Enabled", "true");
    }
}

Java HTTP Client

Micronaut framework 4 offers a new implementation of the Micronaut HTTP Client. You can keep using the Netty-based implementation or use a lighter implementation based on the Java HTTP Client

Please refer to this recording about the new HTTP Client for further explanation.

Client/Server Generation From an OpenAPI Spec

Both Gradle and Maven plugins support the generation of code for an HTTP client or server given an OpenAPI Specification file.  

YAML Configuration

Micronaut framework 4.0 no longer exposes SnakeYAML as a transitive dependency.

JSON Serialisation

Micronaut framework 4.0 does not expose Micronaut Jackson Databind as a transitive dependency. You have to choose whether you want to use Micronaut Serialization or Micronaut Jackson databind.

Jakarta Transition

We have finished the Jakarta transition. Instead of using javax.validation use jakarta.validation. Instead of javax.mail use jakarta.mail. Instead of javax.transaction.Transactional, use jakarta.transaction.Transactional and replace the usage of javax.persistence with jakarta.persistence.

Validation and Annotations on Type Arguments

Micronaut Validation moved to a new repository, and it comes with Bean Validation 3 support.

Micronaut framework 4 compilation time annotation metadata has been extended to support annotations on generic type arguments.

This support enables the ability to support Bean Validation 3 and declarations such as: List<@NotBlank String> names

Improved Modularity 

The built-in Validation, Retry, Service Discovery, HTTP Session and WebSocket features have been split into separate modules allowing removal of this functionality if not needed.

In addition, the compiler has been rewritten allowing the split of compilation only types into a separate core-processor module that is no longer on the user compilation and runtime classpath. This allows for the removal of repackaged versions of ASM and Caffeine.

Cloud Environment Detection Off by Default

To avoid paying the performance hit of detecting cloud environments each time you run or test your application, Micronaut framework 4 turns off cloud environment detection by default. If you rely on cloud environments to be present, please read the Cloud Configuration documentation to learn how you can enable cloud environment detection. Alternatively, you can set the Micronaut environment explicitly in your production environment. 

Mapped Injection

Micronaut framework 4 allows the injection of a java.util.Map of beans where the key is the bean name. The name of the bean is derived from the qualifier or (if not present) the simple name of the class.

Arbitrary Nesting of Configuration Properties

With Micronaut framework 4, it is now possible to nest @ConfigurationProperties and @EachProperty annotations allowing for more dynamic configuration possibilities.

Improved Error Messages

Improved Error Messages for Missing Configuration

Micronaut framework 4 improves error messages to display the configuration that is required to activate the bean when a bean is not present due to missing configuration (such as a bean that uses @EachProperty). 

Improved Error Messages for Missing Beans

When a bean annotated with @EachProperty or @Bean is not found due to missing configuration an error is thrown, showing the configuration prefix necessary to resolve the issue.

Tracking of Disabled Beans

Beans that are disabled via Bean Requirements are now tracked and an appropriate error thrown if a bean has been disabled.

Disabled beans are visible via the Beans Endpoint aiding in understanding the state of your application configuration.

Micronaut Data

Micronaut Data adds support for Hibernate 6, Hibernate Reactive 2, and Oracle JSON-Relational Duality Views.

Every Runtime is Now HTTP Server TCK Compliant

Micronaut framework supports multiple runtimes: 

  • Netty
  • Servlet (Jetty, Undertow, and Tomcat)
  • Serverless (AWS Lambda, Google Cloud Http Functions and Azure HTTP functions)

With Micronaut framework 4, every runtime successfully passes the Micronaut framework HTTP Server TCK (Test Compatibility Kit). 

Micronaut MQTT

Micronaut MQTT adds an implementation based on the HiveMQ MQTT Client.

Object Storage

Object Storage adds Local Storage to ease local development and testing. 

GraphQL 

The GraphQL module now supports the modern graphql-ws protocol for GraphQL subscriptions over WebSockets.

Micronaut Discovery Client

Micronaut Discovery Client supports Spring Cloud client basic authentication.

Micronaut Control Panel

The Micronaut Control Panel is a new module that provides a web UI allowing you to view and manage the state of your Micronaut application, typically in a development environment.

Micronaut AWS Lambda

Micronaut framework 4 offers a major overhaul for Lambda integration. 

With this release, Micronaut AWS offers built-in Lambda handlers for Amazon API Gateway payloads v1 and v2 and a handler for Application Load Balancer. Lambda integration no longer relies on the AWS Serverless Java container library. 

Moreover, micronaut-function-aws provides an implementation of com.amazonaws.services.lambda.runtime.CustomPojoSerializer which is loaded via SPI. This CustomPojoSerialization avoids your Micronaut function to pay a double hit when using a serialization library inside the Lambda function.

Additionally, a new module io.micronaut.aws:micronaut-aws-lambda-events-serde allows you to use Micronaut Serialization with AWS Lambda Java Events.

Dependency Updates:

How to Upgrade to Micronaut Framework 4?

We have published an upgrade to Micronaut framework 4 guide to help you upgrade your Micronaut applications, we also provide an OpenRewrite integration for Gradle and Maven.

Next Steps

Please refer to the documentation for further details, try upgrading your applications and use GitHub to report any issues.

Thanks to all those who contributed to this release! We look forward to your feedback.