Apache Maven

Apache Maven

Apache Maven Péter Jeszenszky Faculty of Informatics, University of Debrecen [email protected] Last modified: January 27, 2020 Apache Maven ● A software project management and comprehension tool with the following objectives: – Making the build process easy. – Providing a uniform build system. – Providing quality project information. – Providing guidelines and best practices for development. – Allowing transparent migration to new features. ● See: https://maven.apache.org/what-is-maven.html 2 Features ● Major features include the following: – Uniform build system – Dependency management – Distribution publication – Reporting and website creation ● See: Feature Summary https://maven.apache.org/maven-features.html 3 Characteristics (1) ● Convention over configuration – E.g., defines a standard project directory layout. ● Defines project lifecycles and lifecycle phases ● Declarative ● Modular and extensible architecture – All of its functionality is provided by plugins. 4 Characteristics (2) ● Although it is used mainly for Java projects, can be also used for other programming languages, such as: – C/C++: ● nar-maven-plugin https://maven-nar.github.io/ https://github.com/maven-nar/nar-maven-plugin ● Native Maven Plugin https://www.mojohaus.org/maven-native/native-maven-plugin/ https://github.com/mojohaus/maven-native – Kotlin: ● kotlin-maven-plugin https://kotlinlang.org/docs/reference/using-maven.html – Scala: ● scala-maven-plugin http://davidb.github.io/scala-maven-plugin/ https://github.com/davidB/scala-maven-plugin 5 Development ● Written in Java ● Free and open source software – Distributed under the Apache License v2. ● The current stable version is 3.6.3 (released on November 25, 2019) – See: Maven Releases History https://maven.apache.org/docs/history.html 6 Installation ● Requires a JDK to be installed, not just a JRE! – JDK 7 or later is required. ● The JAVA_HOME environment variable must be set properly! ● Download the latest version of Apache Maven from here: http://maven.apache.org/download.html ● Installation consists of unpacking an archive and setting the PATH environment variable. 7 Installation (Linux) (1) ● If unpacked in the directory /opt/apache- maven-3.6.3, set the PATH environment variable as shown: – export PATH=/opt/apache-maven- 3.6.3/bin:$PATH ● Hint: add the above command to the /etc/profile.d/maven.sh file in order to be automatically executed. 8 Installation (Linux) (2) ● Alternatively, Apache Maven can be installed via the SDKMAN! tool, executing the following command: sdk install maven ● For the installation instructions of SDKMAN! see: http://sdkman.io/install.html 9 Installation (Windows) ● If unpacked in the directory C:\Program Files\apache-maven-3.6.3 – Add the C:\Program Files\apache-maven- 3.6.3\bin directory to the PATH environment variable. 10 Verifying Successful Installation ● Execute one of the following two equivalent commands in the command line: – mvn –version – mvn -v ● If the installation was successful, you should see the following output: ApacheApache MavenMaven 3.6.33.6.3 (cecedd343002696d0abb50b32b541b8a6ba2883f)(cecedd343002696d0abb50b32b541b8a6ba2883f) MavenMaven home:home: /home/jeszy/.sdkman/candidates/maven/current/home/jeszy/.sdkman/candidates/maven/current JavaJava version:version: 13.0.1,13.0.1, vendor:vendor: OracleOracle Corporation,Corporation, runtime:runtime: /home/jeszy/.sdkman/candidates/java/13.0.1-open/home/jeszy/.sdkman/candidates/java/13.0.1-open DefaultDefault locale:locale: hu_HU,hu_HU, platformplatform encoding:encoding: UTF-8UTF-8 OSOS name:name: "linux","linux", version:version: "5.1.5-050105-generic","5.1.5-050105-generic", arch:arch: "amd64","amd64", family:family: "unix""unix" 11 IDE Integration (1) ● Eclipse: m2eclipse http://www.sonatype.org/m2eclipse http://eclipse.org/m2e/ – Update site: http://download.eclipse.org/technology/m2e/releases/ – The Indigo release of the Eclipse IDE for Java Developers is shipped together with m2eclipse (no installation is required). ● IntelliJ IDEA: Provides built-in Apache Maven support. – See: https://www.jetbrains.com/help/idea/maven.html ● Netbeans: Provides built-in Apache Maven support since version 6.7. – See: http://wiki.netbeans.org/Maven 12 IDE Integration (2) ● Visual Studio Code: Maven support is provided by the Maven for Java extension. – See: ● Maven for Java https://marketplace.visualstudio.com/items?itemName=v scjava.vscode-maven ● Java Project Management in VS Code – Maven https://code.visualstudio.com/docs/java/java-project#_m aven 13 Further Information ● Official documentation: https://maven.apache.org/guides/ ● Free electronic books (licenc: Creative Commons BY- NC-ND): https://www.sonatype.com/ebooks – Maven by Example https://github.com/sonatype/maven-example-en – Maven: The Complete Reference https://github.com/sonatype/maven-reference-en – Repository Management with Nexus https://github.com/sonatype/nexus-book ● Mailing lists: http://maven.apache.org/mail-lists.html 14 Standard Directory Layout (1) ● Standard directory layout for projects: – Introduction to the Standard Directory Layout http://maven.apache.org/guides/introduction/introduc tion-to-the-standard-directory-layout.html 15 Standard Directory Layout (2) project/ src/ main/ java/ resources/ test/ java/ resources/ site/ pom.xml 16 Usage (1) ● Execute the mvn --help or mvn -h command to display usage information and available command line options. ● Apache Maven accepts lifecycle phases (e.g., mvn package) and plugin goals (e.g., mvn site:run) as command line arguments. – Multiple number of such command line arguments can be supplied. – Further options can be passed as system properties in the form -Dname=value 17 Usage (2) ● Plugin goals can be specified in the form groupId:artifactId:version:goal – This syntax is required when a specific version of the plugin must be used or Apache Maven does not associate a prefix with the plugin. – Example: mvn org.codehaus.mojo:versions-maven- plugin:2.7:help 18 Maven Help Plugin (1) ● Intended for querying information about plugins, the runtime environment and the project. – Further information: http://maven.apache.org/plugins/maven-help-plugin/ ● Use the mvn help:help command to display usage information. – Add the -Ddetail=true option for more detailed information. – To display help for a specific goal add the -Dgoal=goal option. ● Example: mvn help:help -Dgoal=describe -Ddetail=true 19 Maven Help Plugin (2) ● The describe goal of the plugin provides information about plugins and lifecycle phases. – Examples of use: ● mvn help:describe -Dplugin=org.apache.maven.plugins:maven-jar- plugin:3.2.0 ● mvn help:describe -Dplugin=jar ● mvn help:describe -Dplugin=jar -Dgoal=sign ● mvn help:describe -Dplugin=jar -Dgoal=sign -Ddetail=true ● mvn help:describe -Dcmd=jar:jar -Ddetail=true ● mvn help:describe -Dcmd=clean 20 Maven Help Plugin (3) ● The effective-pom goal displays the effective POM. – Execution of the mvn help:effective-pom command requires a pom.xml file to be present in the current directory. ● If the file is not there, its path can be specified with the -f or --file option, such as, – mvn help:effective-pom -f ../project/pom.xml 21 Maven Archetype Plugin (1) ● Supports the creation of Maven projects from an existing template called an archetype. – Projects can be created interactively with the command mvn archetype:generate. ● An archetype must be selected, then the Maven coordinates and the packaging must be provided. ● Further information: http://maven.apache.org/archetype/maven-arche type-plugin/ 22 Maven Archetype Plugin (2) ● Since the 2.1 version of the plugin the list of available archetypes can be narrowed down with a filter pattern. – The filter pattern can be specified with the -Dfilter=pattern option ● Example of use: mvn archetype:generate -Dfilter=android 23 Maven Archetype Plugin (3) ● A few useful archetypes: – org.apache.maven.archetypes:maven-archetype-site https://javalibs.com/artifact/org.apache.maven.archetypes/maven-archetype-site – org.glassfish.jersey.archetypes:jersey-example-java8-webapp https://javalibs.com/artifact/org.glassfish.jersey.archetypes/jersey-example-java8-we bapp – org.glassfish.jersey.archetypes:jersey-quickstart-webapp https://javalibs.com/artifact/org.glassfish.jersey.archetypes/jersey-quickstart-webapp – org.wildfly.archetype:wildfly-jakartaee-webapp-archetype https://javalibs.com/artifact/org.wildfly.archetype/wildfly-jakartaee-webapp-archetype – org.openjfx:javafx-archetype-fxml https://javalibs.com/archetype/org.openjfx/javafx-archetype-fxml – org.openjfx:javafx-archetype-simple https://javalibs.com/archetype/org.openjfx/javafx-archetype-simple – … 24 settings.xml (1) ● A configuration file that stores project independent settings. – The $M2_HOME/conf/settings.xml file provides global setting for all users. – Users can place an own settings.xml file in the .m2 directory of their home directory to override global settings. ● On Linux systems the path of this file is ~/.m2/settings.xml. 25 settings.xml (2) ● Reference: https://maven.apache.org/ref/current/maven-sett ings/settings.html ● XML schema: http://maven.apache.org/xsd/settings-1.1.0.xsd 26 settings.xml (3) ● The effective-settings goal of the Maven Help Plugin displays the current configuration settings. – The mvn help:effective-settings command outputs a combination of global and user settings that Maven actually uses. ● Hint: use the global settings.xml file as a template to create a local one. – On Linux systems copy the global settings.xml to your home directory with

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    153 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us