Configuración de plugins
La configuración de plugins en Maven se realiza siempre a través del fichero pom.xml. En general, la configuración de plugins me va a servir para dos cosas:
- Adaptar el funcionamiento de un plugin a la forma que me interese en el proyecto.
- Vincular objetivos de un plugin a fases del ciclo de vida de maven.
A continuación vamos a ver tres ejemplos de cosas que se pueden conseguir por medio de la configuración de plugins.
Contenido
Seleccionar la versión de Java para compilación y ejecución con maven-compiler-plugin
Por defecto, el plugin de compilación de maven fija tanto la versión del código (source) como la versión del .class generado (target) con la versión 1.5 de Java. Si queremos cambiarlo, es necesario configurar el plugin que se encarga de compilar el código (maven-compiler-plugin).
Añadir el siguiente código al método main de la clase App
import java.util.Arrays;
import java.util.List;
[...]
List<String> myList =
Arrays.asList("a1", "a2", "b1", "c2", "c1");
myList
.stream()
.filter(s -> s.startsWith("c"))
.map(String::toUpperCase)
.sorted()
.forEach(System.out::println);
Este código utiliza la funcionalidad de Streams de Java 1.8.
Compilar el código modificado
Observar el mensaje de error. ¿Por qué falla?
Configurar pom.xml para que maven-compiler-plugin use la versión 1.8 de java
<project>
[...]
<build>
[...]
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.7.0</version>
<configuration>
<source>1.8< /source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
[...]
</build>
[...]
</project>
Compilar de nuevo el código
Observar como ahora funciona ya correctamente. Si da errores, comprueba que la versión de JDK que tienes instalada es la 1.8.
Modificar el manifest con maven-jar-plugin
El manifest es un fichero que se puede incluir en los JAR y que indica cuál es el punto de entrada del mismo. Este fichero permite que se pueda ejecutar el JAR directamente con java -jar fichero.jar
en lugar de tener que indicar la clase donde está el método main. Esto se puede conseguir configurando de forma adecuada el maven-jar-plugin para establecer el punto de entrada del mismo.
Moficar el pom.xml
Añadir lo siguiente:
…
<build>
<plugins>
<!-- Make this jar executable -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.6</version>
<configuration>
<!--Pluging configuration -->
<archive>
<manifest>
<!-- Jar file entry point -->
<mainClass>${project.groupId}.App</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
…
Esto configura el plugin jar para que defina el entry point del fichero JAR generado. Esta configuración se aplicará tanto al ejecutar el objetivo "jar:jar" como al ejecutar la fase "package" (a la que está vinculada por defecto el objetivo "jar:jar").
Cree el .jar
mvn clean package
ó
mvn clean jar:jar
¿Qué diferencias hay? ¿Es correcta esta segunda invocación? ¿Por qué?
Ejecute el .jar generado
java -jar target\proy1-1.0-SNAPSHOT.jar
Ups. ¿Por qué falla?
Copiar las dependencias con maven-dependency-plugin
Se establecerá una carpeta dentro de target donde estarán todos los jars dependientes usando el maven-dependency-plugin.
Edite el pom.xml
Añada el siguiente código
...
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.10</version>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}/dependencies</outputDirectory>
<includeScope> runtime </includeScope>
</configuration>
</execution>
</executions>
</plugin>
...
Se ha configurado el plugin dependency. El objetivo copy-dependencies se ha asociado a la fase package y se ha configurado para que las dependencias de runtime se copien en la carpeta dependencies.
Cree el .jar y ejecute
mvn package
java -jar target\proy1-1.0-SNAPSHOT.jar
¿Sigue fallando?
Hay que terminar de configurar el plugin Jar
Hay que añadir las referencias en el manifest. Añada las siguientes líneas de configuración del plugin Jar anterior.
...
<addClasspath>true</addClasspath>
<classpathPrefix> dependencies/</classpathPrefix>
...
¿Vas rápido? -> Tarea adicional
El plugin Jar se ha configurado para que, durante su ejecución dentro del ciclo de vida default, se comporte de cierta manera. Sin embargo, el plugin dependency, que no se ejecuta normalmente, se ha configurado para que sí se ejecute.
Haga, ahora, que se creen 2 jars, uno con la configuración que hemos indicado arriba y otro sin que tenga ninguna configuración por nuestra parte. Esto no es habitualmente recomendable ya que lo ideal es que cada proyecto tenga un único resultado, pero sirve a modo de ejemplo para probar las características de Maven.
Indicación: Además de tocar el atributo manifest
tendrá que tocar el finalName
para que cada jar tenga un nombre diferente (cf. Jar Parameters).