Know your build - so you can make it faster
Maven Build Scanner is a tool that hooks into Maven builds and produces reports and charts that breakdown the time Maven spent. These reports provide insights into your builds that can be used to tune it.
It's been designed to work with large and complex builds; ones with hundreds of modules and plugins.
At Intuit it helped take a 40m build run by hundreds of developers every day and reduce it to 4m - a 10x reduction.
Inspired by Gradle Build Scan.
Start by install the following:
- Java 8
- Maven 3
- Docker
- Node + NPM
Run:
./setup.sh
This will:
- Start up a Mongo database on Docker for storing data.
- Create a JAR for the extension and copies it into your local Maven extensions folder (on MacOS this is something like
/usr/local/Cellar/maven/3.5.4/libexec/lib/ext
) - Build and start the NPM web application for viewing your reports (listening on port 3000).
- Run a quick build scan on itself so you can try out the report.
You can then view your first scan at (http://localhost:3000). The page will show:
- A timeline of the build, so you can see how effective concurrency is being used.
- A pie chart showing the Maven plugins that took the longest.
- A module-by-module breakdown of tasks.
- Links to reports on previous builds.
To create a scan for another application, do the following:
cd your-app
env MAVEN_BUILD_SCANNER=1 mvn install
You should see the following line in the Maven console output:
Open http://localhost:3000/?projectId=com.intuit:maven-build-scanner&sessionId=60acc519-ff2a-4c06-b79a-2aa23c47c861 to view your Maven build scanner results to view your Maven build scanner results
Maven Build Scanner is released under the Apache 2.0 licenses. It uses junit which is licensed under EPL 1.0.