Как заставить Maven использовать мой локальный репозиторий, а не выходить в удаленные репозитории для извлечения артефактов?
Я использую Maven 3.3.3 с Java 8 на Mac Yosemite. У меня есть многомодульный проект.
<modules>
<module>first-module</module>
<module>my-module</module>
…
</modules>
когда я создаю один из моих дочерних модулей, например, "my-module" сверху, используя "mvn clean install", сборка пытается загрузить артефакты дочернего модуля из удаленного репозитория, который я определил в my ~/.м2/настройки.XML-файл. Выход ниже
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building my-module 87.0.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
Downloading: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/maven-metadata.xml
Downloading: http://download.java.net/maven/2/org/mainco/subco/first-module/87.0.0-SNAPSHOT/maven-metadata.xml
Downloaded: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/maven-metadata.xml (788 B at 0.9 KB/sec)
Downloading: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/first-module-87.0.0-20151104.200545-4.pom
как заставить Maven проверить мой локальный ~/.m2 / репозиторий сначала, прежде чем пытаться загрузить из удаленные хранилища? Ниже приведены мои удаленные репозитории, определенные в моем~/.м2/настройки.xml-файл...
<profile>
<id>releases</id>
<activation>
<property>
<name>!releases.off</name>
</property>
</activation>
<repositories>
<repository>
<id>releases</id>
<url>https://my.remoterepository.com/nexus/content/repositories/releases/</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
</profile>
<profile>
<id>snapshots</id>
<activation>
<property>
<name>!snapshots.off</name>
</property>
</activation>
<repositories>
<repository>
<id>snapshots</id>
<url>https://my.remoterepository.com/nexus/content/repositories/snapshots/</url>
<releases>
<enabled>false</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
</profile>
Edit: в ответ на ответ, говорящий, что загрузка происходит между артефактом не было, ниже вывод терминала, в котором я доказываю, что файл был там в моем РЕПО, но Maven пытается загрузить его в любом случае ...
Daves-MacBook-Pro-2:my-module davea$ ls -al ~/.m2/repository/org/mainco/subco/first-module/87.0.0-SNAPSHOT/first-module-87.0.0-SNAPSHOT.jar
-rw-r--r-- 1 davea staff 10171 Nov 5 10:22 /Users/davea/.m2/repository/org/mainco/subco/first-module/87.0.0-SNAPSHOT/first-module-87.0.0-SNAPSHOT.jar
Daves-MacBook-Pro-2:my-module davea$ mvn clean install
[INFO] Scanning for projects...
[WARNING]
[WARNING] Some problems were encountered while building the effective model for org.mainco.subco:my-module:jar:87.0.0-SNAPSHOT
[WARNING] 'build.plugins.plugin.(groupId:artifactId)' must be unique but found duplicate declaration of plugin org.apache.maven.plugins:maven-antrun-plugin @ org.mainco.subco:my-module:[unknown-version], /Users/davea/Documents/sb_workspace/my-module/pom.xml, line 678, column 12
[WARNING]
[WARNING] It is highly recommended to fix these problems because they threaten the stability of your build.
[WARNING]
[WARNING] For this reason, future Maven versions might no longer support building such malformed projects.
[WARNING]
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building my-module 87.0.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
Downloading: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/maven-metadata.xml
Downloading: http://download.java.net/maven/2/org/mainco/subco/first-module/87.0.0-SNAPSHOT/maven-metadata.xml
Downloaded: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/maven-metadata.xml (788 B at 0.8 KB/sec)
Downloading: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/first-module-87.0.0-20151106.043202-8.pom
Downloaded: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/first-module/87.0.0-SNAPSHOT/first- module-87.0.0-20151106.043202-8.pom (3 KB at 21.9 KB/sec)
Downloading: http://download.java.net/maven/2/org/mainco/subco/subco/87.0.0-SNAPSHOT/maven-metadata.xml
Downloading: https://my.remoterepository.com/nexus/content/repositories/snapshots/org/mainco/subco/subco/87.0.0-SNAPSHOT/maven-metadata.xml
5 ответов
зависимость имеет версию моментального снимка. Для моментальных снимков Maven проверит локальный репозиторий, и если артефакт, найденный в локальном репозитории, слишком стар, он попытается найти обновленный в удаленных репозиториях. Вероятно, это то, что вы видите.
обратите внимание, что это поведение контролируется updatePolicy
использовать mvn --help
и вы можете увидеть список опций.
есть такой вариант, как -nsu,--no-snapshot-updates Suppress SNAPSHOT updates
Так что используйте команду mvn install -nsu
может принудительно компилироваться с локальным репозиторием.
по-настоящему силу maven к только используйте локальное РЕПО, вы можете работать с mvn <goals> -o
. The -o
говорит maven, чтобы вы работали "в автономном режиме", и он будет оставаться вне сети.
в моем случае у меня был многомодульный проект, как и у вас. Мне пришлось изменить идентификатор группы одной из внешних библиотек, от которых зависел мой проект, как показано ниже.
From:
<dependencyManagement>
<dependency>
<groupId>org.thirdparty</groupId>
<artifactId>calculation-api</artifactId>
<version>2.0</version>
<type>jar</type>
<scope>provided</scope>
</dependency>
<dependencyManagement>
в:
<dependencyManagement>
<dependency>
<groupId>org.thirdparty.module</groupId>
<artifactId>calculation-api</artifactId>
<version>2.0</version>
<type>jar</type>
<scope>provided</scope>
</dependency>
<dependencyManagement>
обратите внимание на раздел . Оказалось, что я забыл модифицировать соответствующий раздел подмодулей, которые определяют эту зависимость в своих POM-файлах.
это сводило меня с ума, потому что модуль был доступно локально.
Maven всегда сначала проверяет ваш локальный репозиторий, однако ваша зависимость должна быть установлена в вашем репо, чтобы maven ее нашел.
Run mvn install
сначала в модуле зависимостей, а затем создайте свой зависимый модуль.