配置Maven mirror

文章目录

    • Maven出现 Maven Cannot resolve plugin xxx
    • 配置文件地址
    • 配置文件元素介绍
    • Mirror简介
    • 修改配置

Maven出现 Maven Cannot resolve plugin xxx

这种情况多半是网络问题 下载不了
可以在settings.xml配置 mirror

配置文件地址

settings.xml文件会在两个目录下存在
1、Maven安装目录(全局):%MAVEN_HOME%\conf\settings.xml
2、用户安装目录(用户):${user.home}\.m2\settings.xml
第一个是全局配置,第二个是用户配置。当两者都存在,它们的内容将被合并,特定于用户的settings.xml文件占主导地位。
如果从头开始创建用户特定的配置,可以将全局的settings.xml复制到${user.home}.m2目录下。

配置文件元素介绍

1.localRepository:
表示Maven用来在本地储存信息的本地仓库的目录。默认是用户家目录下面的.m2/repository目录。

2.interactiveMode:
表示是否使用交互模式,默认是true;如果设为false,那么当Maven需要用户进行输入的时候,它会使用一个默认值。

3.offline:
表示是否离线,默认是false。这个属性表示在Maven进行项目编译和部署等操作时是否允许Maven进行联网来下载所需要的信息。

4.pluginGroups:
在pluginGroups元素下面可以定义一系列的pluginGroup元素。表示当通过plugin的前缀来解析plugin的时候到哪里寻找。pluginGroup元素指定的是plugin的groupId。默认情况下,Maven会自动把org.apache.maven.plugins和org.codehaus.mojo添加到pluginGroups下。

5.proxies:
其下面可以定义一系列的proxy子元素,表示Maven在进行联网时需要使用到的代理。当设置了多个代理的时候第一个标记active为true的代理将会被使用

6.servers:
其下面可以定义一系列的server子元素,表示当需要连接到一个远程服务器的时候需要使用到的验证方式。这主要有username/password和privateKey/passphrase这两种方式

7.mirrors:
用于定义一系列的远程仓库的镜像。我们可以在pom中定义一个下载工件的时候所使用的远程仓库。但是有时候这个远程仓库会比较忙,所以这个时候人们就想着给它创建镜像以缓解远程仓库的压力,也就是说会把对远程仓库的请求转换到对其镜像地址的请求。每个远程仓库都会有一个id,这样我们就可以创建自己的mirror来关联到该仓库,那么以后需要从远程仓库下载工件的时候Maven就可以从我们定义好的mirror站点来下载,这可以很好的缓解我们远程仓库的压力。在我们定义的mirror中每个远程仓库都只能有一个mirror与它关联,也就是说你不能同时配置多个mirror的mirrorOf指向同一个repositoryId。

8.profiles:
用于指定一系列的profile。profile元素由activation、repositories、pluginRepositories和properties四个元素组成。当一个profile在settings.xml中是处于活动状态并且在pom.xml中定义了一个相同id的profile时,settings.xml中的profile会覆盖pom.xml中的profile。

9.activeProfiles:
底包含一系列的activeProfile元素,表示对于所有的pom都处于活跃状态的profile。

Mirror简介

mirror相当于一个拦截器,它会拦截maven对remote repository的相关请求,把请求里的remote repository地址,
重定向到mirror里配置的地址。
maven的mirror是镜像,只有当前一个mirror无法连接的时候,才会去找后一个。
当第一个mirror中不存在时候,并不会去第二个mirror中查找,甚至于,maven根本不会去其他的mirror地址查询。

我们可以在pom中定义一个下载工件的时候所使用的远程仓库。但是有时候这个远程仓库会比较忙,所以这个时候人们就想着给它创建镜像以缓解远程仓库的压力,也就是说会把对远程仓库的请求转换到对其镜像地址的请求。每个远程仓库都会有一个id,这样我们就可以创建自己的mirror来关联到该仓库,那么以后需要从远程仓库下载工件的时候Maven就可以从我们定义好的mirror站点来下载,这可以很好的缓解我们远程仓库的压力。在我们定义的mirror中每个远程仓库都只能有一个mirror与它关联,也就是说你不能同时配置多个mirror的mirrorOf指向同一个repositoryId。

  1. id:
      是用来区别mirror的,所有的mirror不能有相同的id
  2. mirrorOf:
      用来表示该mirror是关联的哪一个仓库,其值为其关联仓库的id。当要同时关联多个仓库时,这多个仓库之间可以用逗号隔开;当要关联所有的仓库时,可以使用“”表示;当要关联除某一个仓库以外的其他所有仓库时,可以表示为“,!repositoryId”;当要关联不是localhost或用file请求的仓库时,可以表示为“external:*”。
  3. url:
      表示该镜像的url。当Maven在建立系统的时候就会使用这个url来连接到我们的远程仓库。

另外  
标签里面放置的是要被镜像的Repository ID。为了满足一些复杂的需求,Maven还支持更高级的镜像配置:

<mirrorOf>*mirrorOf> 匹配所有远程仓库。 
<mirrorOf>repo1,repo2mirrorOf> 匹配仓库repo1和repo2,使用逗号分隔多个远程仓库。 
<mirrorOf>*,!repo1miiroOf>匹配所有远程仓库,repo1除外,使用感叹号将仓库从匹配中排除。 

注意:需要注意的是,由于镜像仓库完全屏蔽了被镜像仓库,当镜像仓库不稳定或者停止服务的时候,Maven仍将无法访问被镜像仓库,因而将无法下载构件。

修改配置

修改配置增加以下节点


<mirror>
  <id>aliyunmavenid>
  <mirrorOf>*mirrorOf>
  <name>阿里云公共仓库name>
  <url>https://maven.aliyun.com/repository/publicurl>
mirror>

如果想使用其它代理仓库,可在节点中加入对应的仓库使用地址。以使用 spring 代理仓为例:

<repository>
  <id>springid>
  <url>https://maven.aliyun.com/repository/springurl>
  <releases>
    <enabled>trueenabled>
  releases>
  <snapshots>
    <enabled>trueenabled>
  snapshots>
repository>

其它代理仓库地址
https://maven.aliyun.com/mvn/view

你可能感兴趣的:(常用)