Estou usando o Maven 3.3.3 com Java 8 no Mac Yosemite. Tenho um projeto multi-módulo.
<modules>
<module>first-module</module>
<module>my-module</module>
…
</modules>
Quando eu construo meu um dos meus módulos filho, por exemplo, “meu-módulo” acima, usando “instalação limpa mvn”, o build tenta baixar os artefatos do módulo filho de um repositório remoto que defini em meu ~ / .m2 Arquivo /settings.xml. A saída está abaixo
[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
Como faço para forçar o Maven a verificar meu repositório ~ / .m2 / local primeiro, antes de tentar fazer o download dos repositórios remotos? Abaixo está onde tenho meus repositórios remotos definidos no meu arquivo ~ / .m2 / settings.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: Em resposta à resposta dizendo que o download ocorre quando o artefato não está lá, abaixo está a saída do terminal em que provo que o arquivo estava lá no meu repositório, mas o Maven está tentando baixá-lo mesmo assim ...
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
fonte
settings.xml
(veja aqui ).Respostas:
A dependência possui uma versão de instantâneo. Para instantâneos, o Maven irá verificar o repositório local e se o artefato encontrado no repositório local for muito antigo, ele tentará encontrar um atualizado nos repositórios remotos. Provavelmente é isso que você está vendo.
Observe que esse comportamento é controlado pela
updatePolicy
diretiva na configuração do repositório (que édaily
por padrão para repositórios de instantâneos).fonte
Use
mvn --help
e você pode ver a lista de opções.Existe uma opção como
-nsu,--no-snapshot-updates Suppress SNAPSHOT updates
Portanto, o comando de uso
mvn install -nsu
pode forçar a compilação com o repositório local.fonte
-o
para comportamento de maven "offline"Para realmente forçar o maven a usar apenas seu repositório local, você pode executar com
mvn <goals> -o
. O-o
maven diz para deixá-lo trabalhar "offline" e permanecerá fora da rede.fonte
mvn dependency:go-offline
No meu caso, tive um projeto multimódulo como você. Tive que alterar um ID de grupo de uma das bibliotecas externas do meu projeto, conforme mostrado abaixo.
De:
Para:
Preste atenção na seção <groupId>. Acontece que eu estava esquecendo de modificar a seção correspondente dos submódulos que definem essa dependência em seus arquivos pom.
Isso me deixou muito louco porque o módulo estava disponível localmente.
fonte
Siga as etapas abaixo:
Por exemplo, arquivos como .repositórios, .pom, .sha1, .lastUpdated etc.
mvn clean install -o
comandoIsso ajudará a usar arquivos jar do repositório local em vez de se conectar a qualquer repositório.
fonte
*.repositories
e*.sha1
arquivos funcionou para mimA opção -o não funcionou para mim porque o artefato ainda está em desenvolvimento e ainda não foi carregado e o maven (3.5.x) ainda tenta baixá-lo do repositório remoto porque é a primeira vez, de acordo com o erro que recebo.
No entanto, isso corrigiu para mim: https://maven.apache.org/general.html#importing-jars
Após esta instalação manual, não há necessidade de usar a opção offline.
ATUALIZAR
Acabei de reconstruir a dependência e tive que importá-la novamente: o regular
mvn clean install
não era suficiente para mimfonte
O Maven sempre verifica seu repositório local primeiro, entretanto, sua dependência precisa ser instalada em seu repo para que o maven o encontre.
Execute primeiro
mvn install
em seu módulo de dependência e, em seguida, crie seu módulo dependente.fonte