Maven setting配置镜像仓库

国内Maven镜像仓库值得收藏

1.配置IDE构建的Maven存放目录(解压目录)

2.配置IDE的User setting file路径,修改setting配置文件

  配置本地仓库

   1 <!--自定义本地仓库路径-->

  2 <localRepository>E:\JAVA\Maven</localRepository>

  配置mirrors远程镜像(一般配置一到两个镜像) 

 1 <mirrors>
 2     <!-- mirror
 3      | Specifies a repository mirror site to use instead of a given repository. The repository that
 4      | this mirror serves has an ID that matches the mirrorOf element of this mirror. IDs are used
 5      | for inheritance and direct lookup purposes, and must be unique across the set of mirrors.
 6      |
 7     <mirror>
 8       <id>mirrorId</id>
 9       <mirrorOf>repositoryId</mirrorOf>
10       <name>Human Readable Name for this Mirror.</name>
11       <url>http://my.repository.com/repo/path</url>
12     </mirror>
13      -->
14     <mirror>
15         <id>alimaven</id>
16         <mirrorOf>central</mirrorOf>
17         <name>aliyun maven</name>
18         <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
19     </mirror>
20     <mirror>
21         <id>jboss-public-repository-group</id>
22         <mirrorOf>central</mirrorOf>
23         <name>JBoss Public Repository Group</name>
24         <url>http://repository.jboss.org/nexus/content/groups/public</url>
25     </mirror>
26 </mirrors>

  配置profiles构建  

 1 <profile>
 2     <id>jdk18</id>
 3     <activation>
 4         <jdk>1.8</jdk>
 5         <activeByDefault>true</activeByDefault>
 6     </activation>
 7     <properties>
 8         <maven.compiler.source>1.8</maven.compiler.source>
 9         <maven.compiler.target>1.8</maven.compiler.target>
10         <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
11     </properties>
12 </profile>

  国内Maven镜像仓库值得收藏 

 1 <mirror>
 2     <id>alimaven</id>
 3     <name>aliyun maven</name>
 4     <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
 5     <mirrorOf>central</mirrorOf>
 6 </mirror>
 7 <mirror>
 8     <id>alimaven</id>
 9     <mirrorOf>central</mirrorOf>
10     <name>aliyun maven</name>
11     <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
12 </mirror>
13
14 <mirror>
15     <id>ibiblio</id>
16     <mirrorOf>central</mirrorOf>
17     <name>Human Readable Name for this Mirror.</name>
18     <url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
19 </mirror>
20 <mirror>
21     <id>jboss-public-repository-group</id>
22     <mirrorOf>central</mirrorOf>
23     <name>JBoss Public Repository Group</name>
24     <url>http://repository.jboss.org/nexus/content/groups/public</url>
25 </mirror>
26
27 <mirror>
28     <id>central</id>
29     <name>Maven Repository Switchboard</name>
30     <url>http://repo1.maven.org/maven2/</url>
31     <mirrorOf>central</mirrorOf>
32 </mirror>
33 <mirror>
34     <id>repo2</id>
35     <mirrorOf>central</mirrorOf>
36     <name>Human Readable Name for this Mirror.</name>
37     <url>http://repo2.maven.org/maven2/</url>
38 </mirror>

  完整setting配置  

  1 <?xml version="1.0" encoding="UTF-8" ?>
  2
  3 <!--
  4 Licensed to the Apache Software Foundation (ASF) under one
  5 or more contributor license agreements.  See the NOTICE file
  6 distributed with this work for additional information
  7 regarding copyright ownership.  The ASF licenses this file
  8 to you under the Apache License, Version 2.0 (the
  9 "License"); you may not use this file except in compliance
 10 with the License.  You may obtain a copy of the License at
 11
 12     http://www.apache.org/licenses/LICENSE-2.0
 13
 14 Unless required by applicable law or agreed to in writing,
 15 software distributed under the License is distributed on an
 16 "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 17 KIND, either express or implied.  See the License for the
 18 specific language governing permissions and limitations
 19 under the License.
 20 -->
 21
 22 <!--
 23  | This is the configuration file for Maven. It can be specified at two levels:
 24  |
 25  |  1. User Level. This settings.xml file provides configuration for a single user,
 26  |                 and is normally provided in ${user.home}/.m2/settings.xml.
 27  |
 28  |                 NOTE: This location can be overridden with the CLI option:
 29  |
 30  |                 -s /path/to/user/settings.xml
 31  |
 32  |  2. Global Level. This settings.xml file provides configuration for all Maven
 33  |                 users on a machine (assuming they‘re all using the same Maven
 34  |                 installation). It‘s normally provided in
 35  |                 ${maven.home}/conf/settings.xml.
 36  |
 37  |                 NOTE: This location can be overridden with the CLI option:
 38  |
 39  |                 -gs /path/to/global/settings.xml
 40  |
 41  | The sections in this sample file are intended to give you a running start at
 42  | getting the most out of your Maven installation. Where appropriate, the default
 43  | values (values used when the setting is not specified) are provided.
 44  |
 45  |-->
 46 <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
 47           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 48           xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
 49     <!-- localRepository
 50      | The path to the local repository maven will use to store artifacts.
 51      |
 52      | Default: ${user.home}/.m2/repository
 53     <localRepository>/path/to/local/repo</localRepository>
 54     -->
 55     <!--自定义本地仓库路径-->
 56     <localRepository>E:\JAVA\Maven</localRepository>
 57     <!-- interactiveMode
 58      | This will determine whether maven prompts you when it needs input. If set to false,
 59      | maven will use a sensible default value, perhaps based on some other setting, for
 60      | the parameter in question.
 61      |
 62      | Default: true
 63     <interactiveMode>true</interactiveMode>
 64     -->
 65
 66     <!-- offline
 67      | Determines whether maven should attempt to connect to the network when executing a build.
 68      | This will have an effect on artifact downloads, artifact deployment, and others.
 69      |
 70      | Default: false
 71     <offline>false</offline>
 72     -->
 73
 74     <!-- pluginGroups
 75      | This is a list of additional group identifiers that will be searched when resolving plugins by their prefix, i.e.
 76      | when invoking a command line like "mvn prefix:goal". Maven will automatically add the group identifiers
 77      | "org.apache.maven.plugins" and "org.codehaus.mojo" if these are not already contained in the list.
 78      |-->
 79     <pluginGroups>
 80         <!-- pluginGroup
 81          | Specifies a further group identifier to use for plugin lookup.
 82         <pluginGroup>com.your.plugins</pluginGroup>
 83         -->
 84     </pluginGroups>
 85
 86     <!-- proxies
 87      | This is a list of proxies which can be used on this machine to connect to the network.
 88      | Unless otherwise specified (by system property or command-line switch), the first proxy
 89      | specification in this list marked as active will be used.
 90      |-->
 91     <proxies>
 92         <!-- proxy
 93          | Specification for one proxy, to be used in connecting to the network.
 94          |
 95         <proxy>
 96           <id>optional</id>
 97           <active>true</active>
 98           <protocol>http</protocol>
 99           <username>proxyuser</username>
100           <password>proxypass</password>
101           <host>proxy.host.net</host>
102           <port>80</port>
103           <nonProxyHosts>local.net|some.host.com</nonProxyHosts>
104         </proxy>
105         -->
106     </proxies>
107
108     <!-- servers
109      | This is a list of authentication profiles, keyed by the server-id used within the system.
110      | Authentication profiles can be used whenever maven must make a connection to a remote server.
111      |-->
112     <servers>
113         <!-- server
114          | Specifies the authentication information to use when connecting to a particular server, identified by
115          | a unique name within the system (referred to by the ‘id‘ attribute below).
116          |
117          | NOTE: You should either specify username/password OR privateKey/passphrase, since these pairings are
118          |       used together.
119          |
120         <server>
121           <id>deploymentRepo</id>
122           <username>repouser</username>
123           <password>repopwd</password>
124         </server>
125         -->
126
127         <!-- Another sample, using keys to authenticate.
128         <server>
129           <id>siteServer</id>
130           <privateKey>/path/to/private/key</privateKey>
131           <passphrase>optional; leave empty if not used.</passphrase>
132         </server>
133         -->
134     </servers>
135
136     <!-- mirrors
137      | This is a list of mirrors to be used in downloading artifacts from remote repositories.
138      |
139      | It works like this: a POM may declare a repository to use in resolving certain artifacts.
140      | However, this repository may have problems with heavy traffic at times, so people have mirrored
141      | it to several places.
142      |
143      | That repository definition will have a unique id, so we can create a mirror reference for that
144      | repository, to be used as an alternate download site. The mirror site will be the preferred
145      | server for that repository.
146      |-->
147     <mirrors>
148         <!-- mirror
149          | Specifies a repository mirror site to use instead of a given repository. The repository that
150          | this mirror serves has an ID that matches the mirrorOf element of this mirror. IDs are used
151          | for inheritance and direct lookup purposes, and must be unique across the set of mirrors.
152          |
153         <mirror>
154           <id>mirrorId</id>
155           <mirrorOf>repositoryId</mirrorOf>
156           <name>Human Readable Name for this Mirror.</name>
157           <url>http://my.repository.com/repo/path</url>
158         </mirror>
159          -->
160
161         <mirror>
162             <id>alimaven-central</id>
163             <mirrorOf>central</mirrorOf>
164             <name>aliyun maven</name>
165             <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
166         </mirror>
167         <mirror>
168             <id>jboss-public-repository-group</id>
169             <mirrorOf>central</mirrorOf>
170             <name>JBoss Public Repository Group</name>
171             <url>http://repository.jboss.org/nexus/content/groups/public</url>
172         </mirror>
173
174         <!--<mirror>
175             <id>alimaven</id>
176             <name>aliyun maven</name>
177             <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
178             <mirrorOf>central</mirrorOf>
179         </mirror>
180
181         <mirror>
182             <id>ibiblio</id>
183             <mirrorOf>central</mirrorOf>
184             <name>Human Readable Name for this Mirror.</name>
185             <url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
186         </mirror>
187
188         <mirror>
189             <id>central</id>
190             <name>Maven Repository Switchboard</name>
191             <url>http://repo1.maven.org/maven2/</url>
192             <mirrorOf>central</mirrorOf>
193         </mirror>
194         <mirror>
195             <id>repo2</id>
196             <mirrorOf>central</mirrorOf>
197             <name>Human Readable Name for this Mirror.</name>
198             <url>http://repo2.maven.org/maven2/</url>
199         </mirror>-->
200
201     </mirrors>
202
203     <!-- profiles
204      | This is a list of profiles which can be activated in a variety of ways, and which can modify
205      | the build process. Profiles provided in the settings.xml are intended to provide local machine-
206      | specific paths and repository locations which allow the build to work in the local environment.
207      |
208      | For example, if you have an integration testing plugin - like cactus - that needs to know where
209      | your Tomcat instance is installed, you can provide a variable here such that the variable is
210      | dereferenced during the build process to configure the cactus plugin.
211      |
212      | As noted above, profiles can be activated in a variety of ways. One way - the activeProfiles
213      | section of this document (settings.xml) - will be discussed later. Another way essentially
214      | relies on the detection of a system property, either matching a particular value for the property,
215      | or merely testing its existence. Profiles can also be activated by JDK version prefix, where a
216      | value of ‘1.4‘ might activate a profile when the build is executed on a JDK version of ‘1.4.2_07‘.
217      | Finally, the list of active profiles can be specified directly from the command line.
218      |
219      | NOTE: For profiles defined in the settings.xml, you are restricted to specifying only artifact
220      |       repositories, plugin repositories, and free-form properties to be used as configuration
221      |       variables for plugins in the POM.
222      |
223      |-->
224     <profiles>
225         <!-- profile
226          | Specifies a set of introductions to the build process, to be activated using one or more of the
227          | mechanisms described above. For inheritance purposes, and to activate profiles via <activatedProfiles/>
228          | or the command line, profiles have to have an ID that is unique.
229          |
230          | An encouraged best practice for profile identification is to use a consistent naming convention
231          | for profiles, such as ‘env-dev‘, ‘env-test‘, ‘env-production‘, ‘user-jdcasey‘, ‘user-brett‘, etc.
232          | This will make it more intuitive to understand what the set of introduced profiles is attempting
233          | to accomplish, particularly when you only have a list of profile id‘s for debug.
234          |
235          | This profile example uses the JDK version to trigger activation, and provides a JDK-specific repo.
236         <profile>
237           <id>jdk-1.4</id>
238
239           <activation>
240             <jdk>1.4</jdk>
241           </activation>
242
243           <repositories>
244             <repository>
245               <id>jdk14</id>
246               <name>Repository for JDK 1.4 builds</name>
247               <url>http://www.myhost.com/maven/jdk14</url>
248               <layout>default</layout>
249               <snapshotPolicy>always</snapshotPolicy>
250             </repository>
251           </repositories>
252         </profile>
253         -->
254         <profile>
255             <id>jdk18</id>
256             <activation>
257                 <jdk>1.8</jdk>
258                 <activeByDefault>true</activeByDefault>
259             </activation>
260             <properties>
261                 <maven.compiler.source>1.8</maven.compiler.source>
262                 <maven.compiler.target>1.8</maven.compiler.target>
263                 <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
264             </properties>
265         </profile>
266
267         <!--
268          | Here is another profile, activated by the system property ‘target-env‘ with a value of ‘dev‘,
269          | which provides a specific path to the Tomcat instance. To use this, your plugin configuration
270          | might hypothetically look like:
271          |
272          | ...
273          | <plugin>
274          |   <groupId>org.myco.myplugins</groupId>
275          |   <artifactId>myplugin</artifactId>
276          |
277          |   <configuration>
278          |     <tomcatLocation>${tomcatPath}</tomcatLocation>
279          |   </configuration>
280          | </plugin>
281          | ...
282          |
283          | NOTE: If you just wanted to inject this configuration whenever someone set ‘target-env‘ to
284          |       anything, you could just leave off the <value/> inside the activation-property.
285          |
286         <profile>
287           <id>env-dev</id>
288
289           <activation>
290             <property>
291               <name>target-env</name>
292               <value>dev</value>
293             </property>
294           </activation>
295
296           <properties>
297             <tomcatPath>/path/to/tomcat/instance</tomcatPath>
298           </properties>
299         </profile>
300         -->
301     </profiles>
302
303     <!-- activeProfiles
304      | List of profiles that are active for all builds.
305      |
306     <activeProfiles>
307       <activeProfile>alwaysActiveProfile</activeProfile>
308       <activeProfile>anotherAlwaysActiveProfile</activeProfile>
309     </activeProfiles>
310     -->
311 </settings>

settings.xml

时间: 2024-10-09 20:17:28

Maven setting配置镜像仓库的相关文章

Maven - 配置镜像仓库

默认仓库的配置(全球中央仓库): 可以打开maven的安装目录/conf/settings.xml文件,配置镜像,找到如下一段配置,这里默认没有配置任何镜像,但是有一个被注释的配置范例: id: 镜像的唯一标识mirrorOf: 表示想对哪个仓库设置镜像,这里填入仓库的id,例如maven全球中央仓库的id为central,也可以为*,*表示所有的仓库都用这个镜像name: 镜像的描述url: 镜像的url 比如我们想配置国内的镜像仓库:<mirrors>  <mirror>   

maven setting 配置仓库,pom.xml中repository不起作用

问题描述 最近做java项目,需要使用公司自己搭建的maven仓库,但是有些包公司的仓库中没有,导致下载失败. 项目环境 jdk:1.8 maven:3.5 问题原因分析 maven的setting文件配置信息如下: <?xml version="1.0" encoding="UTF-8"?> <settings> <localRepository>/data/repository</localRepository>

maven中配置jboss仓库

有两种方式,一种是在项目的pom.xml中<repositories>中添加,这是配置是针对具体的某一个项目,更多时候,我们想把jboss仓库作为所有项目的仓库,这就需要在maven的setting.xml中配置了.建议将maven/conf/setting.xml文件拷贝一份到你本地仓库的目录,作为用户配置文件.打开setting.xml文件,在里面添加一下内容: ... <profiles> ... <profile> <id>jboss-public-

最快的 maven repository--阿里镜像仓库

在settings.xml 中配置,所有项目都会生效 第一步:修改maven根目录下的conf文件夹中的setting.xml文件,内容如下: <mirrors> <mirror> <id>alimaven</id> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/groups/public/</url> <mirr

Maven 系列 四 :仓库

1 . 仓库简介 没有 Maven 时,项目用到的 .jar 文件通常需要拷贝到 /lib 目录,项目多了,拷贝的文件副本就多了,占用磁盘空间,且难于管理.Maven 使用一个称之为仓库的目录,根据构件的坐标统一存储这些构件的唯一副本,在项目中通过依赖声明,可以方便的引用构件. 2 . 仓库的布局 构件都有唯一的坐标,Maven 根据坐标管理构件的存储.如以下对 spring-orm-3.2.0 的存储: 文件路径对应了:groupId/artifactId/version/artifactId

手动搭建Docker本地私有镜像仓库

实验环境:两个Centos7虚拟机,一个是Server,用作客户端,另一个是Registry,用作Docker私有镜像仓库. 基础配置 查看一下两台虚拟机的IP地址 Server的IP地址是192.168.134.151. Registry的IP地址是192.168.134.150. 使用setenforce 0临时关闭SElinux. 打开Server和Registry的内核转发功能 编辑配置文件/etc/sysctl.conf,添加下面的内容: net.ipv4.ip_forward = 1

Harbor镜像仓库使用精简指南

一.使用管理员分配用户 使用管理员登录harbor控制台,进入"系统管理"--"用户管理",点击创建用户: 填写创建用户表单,即分配一个用户账号: 二.新建项目 使用刚才创建的testuser登录harbor控制台,点击右侧"新建项目" 填写项目名称,并设置项目镜像仓库是否支持公开访问(这里设置为公开 ): 创建完成后,可以看到所建的镜像项目的管理界面: 可以针对该项目,添加可以访问的成员,并赋予权限: 其中, 1)概要:显示项目的总体容量,镜像

Jenkins一些简单配置 和 配置Maven国内镜像仓库

最近在阿里云申请一台云主机测试Jenkins + Maven自动化持续部署,在构建过程中经常进程自动退出:由于申请测试的免费云主机配置较低,所以每次在构建的时候会发现访问主机就会变得很卡,最后进程退出.Jenkins权威指南文中描述: 持续集成服务器会使用很多内存.构建会小号内存,多个构建并发运行也会消耗更多的内存.所有在不管你想要同事运行多少构建的情况下,均应该确保构建服务器有足够的RAM来应对.     Jenkins本身自然也需要RAM来运行,但是如果你需要支持大量的构建过程,则仅仅分配给

maven的国内镜像配置

maven阿里云中央仓库 maven作为一个项目管理工具确实非常好用,但是在国内这个网络条件下实在是让人恼火.之前oschina的中央仓库可用,现在oschina的maven服务器关了,一直没找到国内镜像来替代.今天发现阿里云公开了一个中央仓库,大家可以试试. 配置 修改maven根目录下的conf文件夹中的setting.xml文件,内容如下: <mirrors> <mirror> <id>alimaven</id> <name>aliyun