pom.xmlリポジトリの役割、のpluginRepository
pom.xml
役割リポジトリのラベルがある:リモートリポジトリのMavenプロジェクトを構成するために使用されます。例としては、次のとおりです:
<repositories>
<repository>
<id>nexus</id>
<name>Nexus Repository</name>
<url>远程仓库地址</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled> <!--snapshots默认是关闭的,需要开启 -->
</snapshots>
</repository>
</repositories>
上記構成によれば、我々はプロジェクトを作成する場合、あなたはトラブルの多くを設定する必要があり、しかし、このような構成をリモートリポジトリのMavenプロジェクト構成を実現しています。上記内部setting.xmlのリモートリポジトリの達人に構成することができる。これは達成一度に構成することができます
pom.xml
pluginRepository
ラベルの役割は次のとおりです。リモートリポジトリのMavenプラグインを構成するために使用されます。例としては、次のとおりです:
<pluginRepositories>
<pluginRepository>
<id>nexus</id>
<name>Team Nexus Repository</name>
<url>远程仓库地址</url>
</pluginRepository>
</pluginRepositories>
Mavenとネクサス、スナップショットスナップショットリポジトリと発行ライブラリをリリース
依存関係の管理、プロジェクトにフォームポンポンジャーの座標を指定することもできます。このプロセスのことを、どのようにそれを処理を通過するには?どこにjarファイルを見つけるには?どこにjarファイルをダウンロードするには?
この問題は、Mavenとの関係の結びつきを知って、ダウン避けます。
どこにjarファイルを見つけるには?プロジェクトでは、jarファイルを使用し、保存されましたか?これは、さまざまなコンポーネントによって一元管理する倉庫、Mavenのリポジトリの概念につながります。Mavenの倉庫は、ローカルおよびリモートの倉庫倉庫に分割されます。
Mavenは座標に基づいてメンバーを検索する場合は、このコンポーネントのローカルリポジトリの存在は直接使用されている場合、それは最初、ローカルリポジトリを見て、ローカルリポジトリは、このコンポーネントのために存在する、または新しいコンポーネントのバージョンかどうかを確認する必要がない場合、Mavenは見つけるために、リモート倉庫に行きます、必要なコンポーネントを発見した後、その後、地元の倉庫の使用にダウンロード。
ここでは、と答えが出てきます。
まず、ネクサスがリモート倉庫で、導入の部分に応じて、我々はすでに、リモート倉庫の役割を知っています。リモートリポジトリに、デフォルトは、中央倉庫で、中央倉庫のMavenのコアは、リモートリポジトリが付属しています。その後、我々はネクサスをインストールしたいなぜ、中央の倉庫がそれを持っていないでしょうか?
当社の開発プロジェクトの実用的な観点から:
1.いくつかは他のプロジェクトのために依存しているために、そのようにもPWに配備社内プロジェクトとして、外部の倉庫のコンポーネントからダウンロードすることができません。
- 帯域幅と時間を節約するために、そのエージェントと、LAN内のすべての外部リモートリポジトリをプライベートウェアハウス・サーバーをセットアップします。ローカルのMavenプロジェクトのメンバーはPW要求に行き、ダウンロードする必要がある場合にはPWがない場合は、リモート倉庫要求、リモートメンバーからダウンロードした倉庫、プライベートサーバー上のメンバーキャッシュにアクセスしてください。このように、多数の構成要素には、PWがキャッシュされているため、プロジェクト全体がまだ正常に使用することができ、何のタイムリーな一時的なインターネットリンクはありません。それと同時に、また、中央の倉庫への負荷を軽減します。
ネクサスはちょうどPWです。
ネクサスPWへのpom.xmlプロジェクトパッケージのアップロードにdistributionManagementを使用します
1、pom.xmlファイルには、ノードdistributionManagementを追加します
<!-- 使用分发管理将本项目打成jar包,直接上传到指定服务器 -->
<distributionManagement>
<!--正式版本-->
<repository>
<!-- nexus服务器中用户名:在settings.xml中<server>的id-->
<id>yang</id>
<!-- 这个名称自己定义 -->
<name>Release repository</name>
<url>http://192.168.1.105:8081/repository/yang/</url>
</repository>
<!--快照
<snapshotRepository>
<id>nexus-snapshots</id>
<name>Snapshots repository</name>
<url>http://192.168.1.105/repository/yang/</url>
</snapshotRepository>-->
</distributionManagement>
ノードの下の<リポジトリ> <ID> IDサーバは、ファイルsetting.xmlに対応します
<!--maven连接nexus需要验证用户名和密码-->
<server>
<id>yang</id>
<username>admin</username>
<password>admin123</password>
</server>
公式バージョンをアップロードし、のpom.xmlファイルのバージョンは、スナップショット、スナップショットのバージョンを持つことができないだけで
<groupId>com.yang</groupId>
<artifactId>shade-plugin</artifactId>
<version>0.0.1</version>
<!-- <version>0.0.1-SNAPSHOT</version> -->
2、パッケージの実行は、アップロード
したように実行し、右クリックしpom.xmlファイルを- Mavenはビルドし...下のオープンボックスをオンにします。
ライブラリを発行したスナップショットスナップショットリポジトリとリリース
利用Mavenの過程で、私たちはしばしば、おそらく一日に一度リリースされる予定、変更、および公開する任意の時点で、バグの顔を開発段階での不安定な状態にある公共図書館をたくさん持っている、またはN回を解放するためにも、一日。私たちは、Mavenの依存関係の管理は、バージョン管理に基づいている、ということを知って、アーティファクト解放状態のため、バージョン番号が地元新しい、Mavenのよりも私たちの内部のミラーサーバのコンポーネントがダウンロードするためのイニシアチブを取ることはありません場合でも、同じである場合。私たちは、依存関係の管理のための開発段階で正式リリース版に基づいている場合、この問題が発生した、あなたは、コンポーネントのバージョン番号をアップグレードする必要があるので、明らかに要件と実際の状況を満たしていないことができます。それはスナップショットのバージョンに基づいている場合のmavenは私たちにすべての準備ができている間しかし、問題は、自己発熱や自然を解決しています。
maven中的仓库分为两种,snapshot快照仓库和release发布仓库。snapshot快照仓库用于保存开发过程中的不稳定版本,release正式仓库则是用来保存稳定的发行版本。定义一个组件/模块为快照版本,只需要在pom文件中在该模块的版本号后加上-SNAPSHOT即可(注意这里必须是大写),如下:
<groupId>cc.mzone</groupId>
<artifactId>m1</artifactId>
<version>0.1-SNAPSHOT</version>
<packaging>jar</packaging>
maven会根据模块的版本号(pom文件中的version)中是否带有-SNAPSHOT来判断是快照版本还是正式版本。如果是快照版本,那么在mvn deploy时会自动发布到快照版本库中,而使用快照版本的模块,在不更改版本号的情况下,直接编译打包时,maven会自动从镜像服务器上下载最新的快照版本。如果是正式发布版本,那么在mvn deploy时会自动发布到正式版本库中,而使用正式版本的模块,在不更改版本号的情况下,编译打包时如果本地已经存在该版本的模块则不会主动去镜像服务器上下载。
所以,我们在开发阶段,可以将公用库的版本设置为快照版本,而被依赖组件则引用快照版本进行开发,在公用库的快照版本更新后,我们也不需要修改pom文件提示版本号来下载新的版本,直接mvn执行相关编译、打包命令即可重新下载最新的快照库了,从而也方便了我们进行开发。
接下来要介绍的是如何在项目中应用snapshot和release库,应用snapshot和release库达到不同环境下发布不同的版本的目的,首先看一个pom文件的定义:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>net.aty.mybatis</groupId>
<artifactId>mybatis-demo</artifactId>
<packaging>jar</packaging>
<version>${project.release.version}</version>
<name>mybatis-demo</name>
<url>http://maven.apache.org</url>
<properties>
<project.release.version>0.1-SNAPSHOT</project.release.version>
</properties>
<profiles>
<profile>
<id>release</id>
<properties>
<project.release.version>0.1</project.release.version>
</properties>
</profile>
</profiles>
<!--定义snapshots库和releases库的nexus地址-->
<distributionManagement>
<repository>
<id>nexus-releases</id>
<url>
http://172.17.103.59:8081/nexus/content/repositories/releases/
</url>
</repository>
<snapshotRepository>
<id>nexus-snapshots</id>
<url>
http://172.17.103.59:8081/nexus/content/repositories/snapshots/
</url>
</snapshotRepository>
</distributionManagement>
</project>
首先我们看到pom文件中version的定义是采用占位符的形式,这样的好处是可以根据不同的profile来替换版本信息,比如maven默认是使用0.1-SNAPSHOT作为该模块的版本。
1、如果在发布时使用mvn deploy -P release 的命令,那么会自动使用0.1作为发布版本,那么根据maven处理snapshot和release的规则,由于版本号后不带-SNAPSHOT故当成是正式发布版本,会被发布到release仓库;
2. MVNコマンドが発行される展開使用して、それがデフォルトのバージョン0.1-SNAPSHOTを使用する場合、この時間が考慮されますMavenのスナップショットのバージョンは、自動的にスナップショットリポジトリに掲載されます。
distributionManagementセグメントで設定されたアドレスのスナップショットスナップショットリポジトリで、発行されたライブラリを解放し、私がここにあるミラーサーバーとしてネクサスの使用です。メインリポジトリIDとURLの設定については、設定が完了した後、あなたのミラーサーバがユーザ名とパスワードが必要な場合には、当然のことながら、MVNの展開によって解除することができ、あなたも達人のsettings.xmlファイルで次の設定を行う必要があり:
<server>
<id>nexus-releases</id>
<username>admin</username>
<password>admin123</password>
</server>
<server>
<id>nexus-snapshots</id>
<username>admin</username>
<password>admin123</password>
</server>
サーバーのIDの設定がポンポンファイルリポジトリIDのdistributionManagement一貫した対応しなければならないことに注意してください、Mavenは、ログインして解放扱うときにIDの下でリリースされたドキュメントをアップロードするユーザー名とパスワードがあります。
ここでは、唯一、出版スナップショットスナップショットのバージョンとリリースの公式バージョンでプロファイルを定義することで切り替えできる柔軟性を持っている、あなたも依存するコンポーネントであることのプロファイルを使用することができます開発段階でスナップショットリポジトリを使用して定義され、リリース段階で正式なライブラリを機能しますあなたは、プロファイルの異なる特性にデフォルトの属性値をオーバーライドする必要があります。