Micronaut is a modern, JVM-based, full stack microservices framework designed for building modular, easily testable microservice applications.
Micronaut is developed by the creators of the Grails framework and takes inspiration from lessons learnt over the years building real-world applications from monoliths to microservices using Spring, Spring Boot and Grails.
Micronaut aims to provide all the tools necessary to build microservice applications including:
- Dependency Injection and Inversion of Control (IoC)
- Sensible Defaults and Auto-Configuration
- Configuration and Configuration Sharing
- Service Discovery
- HTTP Routing
- HTTP Client with Client-Side Load Balancing
At the same time Micronaut aims to avoid the downsides of frameworks like Spring, Spring Boot and Grails by providing:
- Fast startup time
- Reduced memory footprint
- Minimal use of reflection
- Minimal use of proxies
- Easy Unit Testing
For more information on using Micronaut see the documentation at micronaut.io
To build from source checkout the code and run:
./gradlew publishToMavenLocal
This will publish the current version to your local Maven cache. To get the CLI operational you can do:
export MICRONAUT_HOME=/path/to/checkout
export PATH="$PATH:$MICRONAUT_HOME/cli/build/bin"
You will also need to checkout the Micronaut Profiles and run ./gradlew publishToMavenLocal
there to.
You should then be able to mn create-app hello-world
.
To build the documentation run ./gradlew docs
. The documentation is built to build/docs/index.html
.
If you wish to contribute to the development of Micronaut please read the CONTRIBUTING.md
Micronaut is using Semantic Versioning 2.0.0. To understand what that means, please see the specification documentation. Exclusions to Micronaut's public API include any classes annotated with @Experimental
or @Internal
, which reside in the io.micronaut.core.annotation
package.