-
Notifications
You must be signed in to change notification settings - Fork 260
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[MNGSITE-414] clean up https /maven.apache.org/configure.html #308
Open
ravn
wants to merge
10
commits into
apache:master
Choose a base branch
from
ravn:MNGSITE-414_Clean_up_https_/maven.apache.org/configure.html
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
10 commits
Select commit
Hold shift + click to select a range
6e1e01f
MNGSITE-414: Initial rewrite.
ravn b2c327c
MNGSITE-414: Completed environment variables and files.
ravn fbc8f61
MNGSITE-414: Added sample maven_pre.cmd usage as suggested in https:/…
ravn 7368051
MNGSITE-414: Minor rewording of environment variables.
ravn 0b18884
MNGSITE-414: Preparing for submission.
ravn d40584f
MNGSITE-414: Suggested changes from https://github.com/apache/maven-s…
ravn c577222
MNGSITE-414: Suggested changes from https://github.com/apache/maven-s…
ravn 7ec9b7a
MNGSITE-414: More changes from https://github.com/apache/maven-site/p…
ravn 667cf98
Merge branch 'apache:master' into MNGSITE-414_Clean_up_https_/maven.a…
ravn a3916f4
MNGSITE-414: Additional feedback from https://github.com/apache/maven…
ravn File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -17,42 +17,89 @@ KIND, either express or implied. See the License for the | |
specific language governing permissions and limitations | ||
under the License. | ||
--> | ||
The configuration for Apache Maven usage itself and projects built with resides | ||
in a number of places: | ||
|
||
## `MAVEN_OPTS` environment variable: | ||
Apache Maven ships with two launcher commands in the `${MAVEN_HOME}/bin` directory, | ||
which — based on several environment variables, project files and system files as described below | ||
— constructs and runs the appropriate `java ...` command line which then invokes the Java Virtual Machine (JVM) | ||
that actually runs Maven. | ||
|
||
This variable contains parameters used to start up the JVM running Maven and | ||
can be used to supply additional options to it. E.g. JVM memory | ||
settings could be defined with the value `-Xms256m -Xmx512m`. | ||
* `mvn`: normal way to run from the command line. | ||
* `mvnDebug`: launches `mvn` in debug mode, waiting for a Java debugger to attach to the address specified in `$MAVEN_DEBUG_ADDRESS` (default 8000). | ||
|
||
## `MAVEN_ARGS` environment variable: | ||
|
||
## Environment variables | ||
|
||
In the following the Unix syntax for environment variables is used in the text. | ||
|
||
For Windows the syntax is slightly different, for `$A` use `%A%`. | ||
|
||
### `$MAVEN_OPTS` / `%MAVEN_OPTS%` | ||
|
||
The content of this variable is placed in the `java` command _before_ the class name, and | ||
can therefore be used to provide additional arguments to the Java Virtual Machine (JVM) without | ||
having to specify them on the command line every time. | ||
|
||
Examples include garbage collector and memory configuration, but _not_ options to Maven itself. | ||
|
||
Use `java -help` and `java -X` to see what is possible in this particular JVM. | ||
|
||
<!-- | ||
### `$MAVEN_ARGS` | ||
|
||
Starting with Maven 4, this variable contains arguments passed to Maven before | ||
CLI arguments. E.g., options and goals could be defined with the value | ||
`-B -V checkstyle:checkstyle`. | ||
--> | ||
|
||
|
||
### `$MAVEN_SKIP_RC` / `%MAVEN_SKIP_RC%` | ||
|
||
If set, tells the launcher scripts _not_ to run the various Maven command scripts before and after running the Maven JVM. | ||
This is useful to get standard behavior. | ||
|
||
### `$JAVA_HOME` / `%JAVA_HOME%` | ||
|
||
If set, the Java executable to be used must be found at `$JAVA_HOME/bin/java` or an error will | ||
be reported. If not set, the Java executable is found in the `$PATH`. | ||
|
||
## `settings.xml` file: | ||
### `$MAVEN_DEBUG_OPTS` / `%MAVEN_DEBUG_OPTS%` | ||
|
||
Located in USER_HOME/.m2 the settings files is designed to contain any | ||
configuration for Maven usage across projects. | ||
Additional options for the JVM if needed. | ||
They are put after `$MAVEN_OPTS` and before the `-classpath` argument. | ||
|
||
## `.mvn` directory: | ||
## Files | ||
|
||
Located within the project's top level directory, the files `maven.config`, `jvm.config`, and `extensions.xml` | ||
contain project specific configuration for running Maven. | ||
`${project.basedir}` refers to the top directory of the project. | ||
|
||
This directory is part of the project and may be checked in into your version control. | ||
### `$HOME/.m2/settings.xml` - `%USERPROFILE%\.m2\settings.xml` | ||
|
||
### `.mvn/extensions.xml` file: | ||
This contains the user-specific Maven setup used across projects. | ||
Often this is used to tell Maven to use an internal repository | ||
instead of Maven Central if behind a firewall, | ||
various profiles, and passwords. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. something looks missing here? |
||
|
||
The old way (up to Maven 3.2.5) was to create a jar (must be shaded if you have other dependencies) which contains the extension and put | ||
it manually into the `${MAVEN_HOME}/lib/ext` directory. This means you had to change the Maven installation. The consequence was that everyone | ||
who likes to use this needed to change it’s installation and makes the on-boarding for a developer much more inconvenient. The other | ||
option was to give the path to the jar on command line via `mvn -Dmaven.ext.class.path=extension.jar`. This has the drawback giving those | ||
options to your Maven build every time you are calling Maven. Not very convenient as well. | ||
|
||
From now on this can be done much more simpler and in a more Maven like way. So you can define an `${maven.projectBasedir}/.mvn/extensions.xml` file which looks like the following: | ||
### `${project.basedir}/.mvn/jvm.config`: | ||
|
||
Allows a persistent alternative in the current project to `$MAVEN_OPTS` for providing | ||
additional arguments to the JVM before the class name on the constructed | ||
ravn marked this conversation as resolved.
Show resolved
Hide resolved
|
||
`java ...` command line. Sample contents: | ||
|
||
-Xmx2048m -Xms1024m -XX:MaxPermSize=512m -Djava.awt.headless=true | ||
|
||
Word of caution: If you for any reason need to configure memory usage or the garbage collector | ||
be absolutely certain that the configuration you use | ||
applies to the version of the JVM you are using, and that you understand what you are doing. | ||
|
||
|
||
<!-- | ||
### `${project.basedir}/.mvn/extensions.xml` | ||
|
||
FIXME: WHERE IS THIS DONE? IS THIS MAVEN 4 FUNCTIONALITY? Commented out for now. | ||
|
||
If you for any reason needs additional artifacts put on the classpath used by Maven | ||
in the current project, simply list them here with their usual Maven coordinates. | ||
|
||
|
||
```xml | ||
<extensions xmlns="http://maven.apache.org/EXTENSIONS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||
|
@@ -64,27 +111,19 @@ From now on this can be done much more simpler and in a more Maven like way. So | |
</extension> | ||
</extensions> | ||
``` | ||
--> | ||
|
||
Now you can simply use an extension by defining the usual maven coordinates groupId, artifactId, version as any other artifact. Furthermore all transitive dependencies of those extensions will automatically being downloaded from your repository. So no need to create a shaded artifact anymore. | ||
|
||
### `.mvn/maven.config` file: | ||
|
||
It’s really hard to define a general set of options for calling the maven command line. Starting with Maven 3.3.1+, this can be solved by | ||
putting this | ||
options to a script but this can now simple being done by defining `${maven.projectBasedir}/.mvn/maven.config` file which contains the | ||
configuration options for the `mvn` command line. | ||
### `/usr/local/etc/mavenrc` + `/etc/mavenrc` + `$HOME/.mavenrc` | ||
|
||
For example things like `-T3 -U --fail-at-end`. So you only have to call Maven just by using `mvn | ||
clean package` instead of `mvn -T3 -U --fail-at-end clean package` and not to miss the `-T3 -U --fail-at-end` options on every call. The | ||
`${maven.projectBasedir}/.mvn/maven.config` is located in the `${maven.projectBasedir}/.mvn/` directory; also works if in the root of a multi module build. | ||
Unix-like systems only: | ||
Configuration files executed by the Unix launcher scripts first thing, unless | ||
the environment variable `$MAVEN_SKIP_RC` is set. | ||
|
||
### `.mvn/jvm.config` file: | ||
Typically, environment variables including `$PATH` are set here. | ||
|
||
Starting with Maven 3.3.1+ you can define JVM configuration via `${maven.projectBasedir}/.mvn/jvm.config` file which means you can define the options for your build on a per project base. This file will become part of your project and will be checked in along with your project. So no need anymore for `MAVEN_OPTS`, `.mavenrc` files. So for example if you put the following JVM options into the `${maven.projectBasedir}/.mvn/jvm.config` file | ||
|
||
-Xmx2048m -Xms1024m -XX:MaxPermSize=512m -Djava.awt.headless=true | ||
--- | ||
|
||
You don't need to use these options in `MAVEN_OPTS` or switch between different configurations. | ||
|
||
## Other guides | ||
|
||
|
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Applies to both Windows and POSIX-like