Help coderanch get a
new server
by contributing to the fundraiser
  • Post Reply Bookmark Topic Watch Topic
  • New Topic
programming forums Java Mobile Certification Databases Caching Books Engineering Micro Controllers OS Languages Paradigms IDEs Build Tools Frameworks Application Servers Open Source This Site Careers Other Pie Elite all forums
this forum made possible by our volunteer staff, including ...
Marshals:
  • Campbell Ritchie
  • Ron McLeod
  • Paul Clapham
  • Devaka Cooray
  • Liutauras Vilda
Sheriffs:
  • Jeanne Boyarsky
  • paul wheaton
  • Henry Wong
Saloon Keepers:
  • Stephan van Hulst
  • Tim Holloway
  • Tim Moores
  • Carey Brown
  • Mikalai Zaikin
Bartenders:
  • Lou Hamers
  • Piet Souris
  • Frits Walraven

Run a Maven project without installing Maven

 
Greenhorn
Posts: 1
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Possible odd question here, but do I actually need to install Maven on my device?
I first found out about Maven trying to work on open source (way out of my league), but working on a personal project using Intellij IDEA I was able to create a Maven project, add dependencies, and run it with no issues so far.

Only today when I decided to look at some tutorials did I notice it's actually something you need to install. Both my cmd and IDE terminal don't recognize any mvn commands and I'm unsure of whether or not I am looking at a problem.
 
Saloon Keeper
Posts: 15705
367
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Welcome to CodeRanch!

It depends. Some projects bundle a Maven executable with the source code, so you don't have to separately install Maven. These bundled Maven binaries are called a "Maven wrapper" and you can tell whether the project you're working on has it by looking at the project's root folder and seeing if there's a "mvnw" executable inside of it. If so, you'd use mvnw instead of mvn.

Most projects don't bundle a Maven wrapper though. So yes, it's very likely that you have to install Maven on your system first.
 
Saloon Keeper
Posts: 28062
198
Android Eclipse IDE Tomcat Server Redhat Java Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Maven is a build system. Its primary purpose is to create modules (or "artefacts") such as Web applications, Library JARs, stand-alone executable JARs and the like using a well-defined project directory structure, implied built rules and a request to build one or more goals.

Unlike Ant, which requires you to write your own build rules and define your own directory structure, Maven takes advantage of the "If you've seen one Java project, you've seen them all" approach. Which isn't strictly true, but for the most common types of artefact, it's close enough.

Thus, all files constructed by Maven are placed under a master output directory named /target. Mainline Java source code is under /src/main/java. Unit tests sources are kept separately under /src/test/java so that test files don't get built into production code. Property files and other data files go under /src/main/resources. And so forth.

There is also a master project definition file called the POM (pom.xml) that indicates fine details about the project such as its formal name and version and any dependencies that Maven may need to pull in to do its work.

You can then run goals against the project. For example, "mvn clean" runs the "clean" goal, which simply deletes the /target directory and everything under it. Thanks to the way Maven is organized, I can take a Maven project, run the "clean" goal, ZIP it up and ship it to some faraway land. The recipient can then exactly rebuild everything by unzipping the project and running Maven. The only two things that the recipient needs are compatible versions of Maven (which you can download from https://maven.apache.org and install by unzipping maven and setting the MVN_HOME environment variable (for convenience, add MVN_HOME/bin to your command PATH). And, of course, a compatible version of Java to do the actual compiling and related work. That's all. Just those 2 applications plus your project!

In its basic form, Maven simply takes source and builds an artefact. However, Maven can be extended and goals can be added that will, for example, launch the artefact into a Tomcat webapp server. That's something a lot of people like to do, but it's not actually essential and I prefer not to, myself.

Maven pairs well with IDEs. Generally an IDE will either have a Maven plugin pre-installed as part of the IDE or one can be downloaded and plugged into the IDE. The advantage here is that it makes certain popular Maven functions available from the IDE's menus and toolbars, plus often makes the maven aspects of the project easier to visualize (for example, you can get a dependency graph in an IDE window).
 
Bartender
Posts: 2438
13
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Hi, Tim,
When we use IntelliJ to create a brand new Maven project, there is an archeType option. What is archeType option ? How do we know which option to pick?

There is a documentation here https://maven.apache.org/guides/introduction/introduction-to-archetypes.html
But from your point of view, can you explain archeType and which one topic ?
 
Tim Holloway
Saloon Keeper
Posts: 28062
198
Android Eclipse IDE Tomcat Server Redhat Java Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Archetypes are generic projects. You would normally use one to create the basic layout of a common project, replicate it, and customize the replicas.

In short, you can take any Maven project and catalog it as an archetype.

Maven has quite a few archetypes in its standard repositories, from basic JARs and WARs to stuff like JSF-based webapp projects. Be aware, however, that those archetypes are not given the love that the artefact components are. They're often un-documented and frequently out-of-date.

You can use the archetype feature to create a new Maven project quickly, but you can also just create the project from scratch or steal-and-modify another project.
 
reply
    Bookmark Topic Watch Topic
  • New Topic