JMH benchmark for the popular Java template engines:
- Freemarker
- Mustache
- Pebble
- Thymeleaf
- Velocity
- Download the source code and build it (
mvn clean install
) - Run the benchmark suite with
java -jar target/benchmarks.jar
- Run benchmark while exporting results to csv with
java -jar target/benchmarks.jar -rff results.csv -rf csv
- Use gnuplot to generate plot with
gnuplot benchmark.plot
. This will outputresults.png
.
It is imperative that each template engine is configured in way to reflect real-world usage as opposed to it's optimal configuration. Typically this means an out-of-the-box configuration.
To strive for a common set of features across template engines, the following configurations are expected:
- Disabling of HTML escaping
- Template loaded from classpath prior to actual benchmark
The benchmarks measure throughput, given in "ops/time". The time unit used is seconds. Generally, the score represents the number of templates rendered per second; the higher the score, the better.