Java Maven リモートリポジトリとローカルリポジトリの活用

javascript code
目次

Mavenリポジトリの種類

Mavenのリポジトリは以下のように分類されます.

  • リモートリポジトリ:公開されているリポジトリ
    • セントラルリポジトリ:Mavenによって管理されているリポジトリ
    • セントラル以外のリポジトリ:Maven以外の組織で管理されているリポジトリ
  • ローカルリポジトリ:自身の組織内で利用する非公開のリポジトリ

リモートリポジトリ(セントラルリポジトリ)の利用

セントラルリポジトリの情報は暗黙で定義されています.そのため,セントラルリポジトリを利用するのに特別な手順は不要です.従来どおり以下のように行うことでライブラリを利用できます.

  • ライブラリを利用したいプロジェクトをMaven Central Repository Searchで検索
  • ライブラリのスニペットをpom.xmlのdependenciesまたはbuildsに追加

リモートリポジトリ(セントラル以外)の利用

セントラル以外のリポジトリを利用する場合は,リポジトリの情報をpom.xmlに記載する必要があります.ここでは例としてSpringのAspectJを利用します.

ライブラリを利用するプロジェクトを作成します

% mvn archetype:generate

プロジェクトの情報として以下を設定します.

groupId: org.example
artifactId: repository-sample
version: 1.0-SNAPSHOT
packaging: jar
name: repository-sample

pom.xmlを編集します

編集のポイントは3点です.

  1. spring.orgのリポジトリを追加
  <repositories>
    <repository>
      <id>spring.org</id>
      <name>spring foundation repository</name>
      <url>http://repo.spring.io/release/</url>
    </repository>
  </repositories>
  1. aspectjのdependencyを追加
    <dependency>
      <groupId>org.aspectj</groupId>
      <artifactId>aspectjrt</artifactId>
      <version>1.9.19</version>
    </dependency>
  1. exec:javaを実行できるようにexec-maven-pluginをbuildに追加
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>3.1.0</version>
        <configuration>
          <mainClass>org.example.App</mainClass>
        </configuration>
      </plugin>

pom.xmlの全体はこちらです.

<?xml version="1.0" encoding="UTF-8"?>

<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/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>org.example</groupId>
  <artifactId>repository-sample</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>repository-sample</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>
  <repositories>
    <repository>
      <id>spring.org</id>
      <name>spring foundation repository</name>
      <url>http://repo.spring.io/release/</url>
    </repository>
  </repositories>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.aspectj</groupId>
      <artifactId>aspectjrt</artifactId>
      <version>1.9.19</version>
    </dependency>
  </dependencies>

  <build>
    <plugins>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>3.1.0</version>
        <configuration>
          <mainClass>org.example.App</mainClass>
        </configuration>
      </plugin>
    </plugins>
    <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
      <plugins>
        <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-jar-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
        <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
        <plugin>
          <artifactId>maven-site-plugin</artifactId>
          <version>3.7.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-project-info-reports-plugin</artifactId>
          <version>3.0.0</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>

プロジェクトのパッケージ化

mvn packageします.問題なくpackageゴールが完了します.

% mvn package

以上がセントラルリポジトリ以外のリモートリポジトリを使う方法です.

ローカルプロジェクトの利用

次にローカルプロジェクトの利用です.これは自身で作成したプロジェクトをjarとしてライブラリ化したものを,他のプロジェクトで使いたいといったケースが該当します.

ライブラリ用プロジェクトの作成

% mvn archetype:generate

プロジェクトの情報として以下を設定します.

groupId: org.example.lib
artifactId: mvn-lib
version: 1.0
packaging: jar
name: my-maven-library

pom.xmlを編集します.exec:javaが利用できるようにbuildにexec-maven-pluginを追加します.

<?xml version="1.0" encoding="UTF-8"?>

<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/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>org.example.lib</groupId>
  <artifactId>mvn-lib</artifactId>
  <version>1.0</version>
  <packaging>jar</packaging>

  <name>my-maven-library</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
  </dependencies>

  <build>
    <plugins>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>1.5.0</version>
        <configuration>
          <mainClass>org.example.lib.App</mainClass>
        </configuration>
      </plugin>
    </plugins>
    <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
      <plugins>
        <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-jar-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
        <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
        <plugin>
          <artifactId>maven-site-plugin</artifactId>
          <version>3.7.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-project-info-reports-plugin</artifactId>
          <version>3.0.0</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>

App.javaを編集します

package org.example.lib;

public class App {
    public static void main(String[] args) {
        System.out.println(new Lib("Hanako", 29));
    }
}

AppTest.javaにも簡単なテストを書いておきます.

package org.example.lib;

import static org.junit.Assert.assertTrue;

import junit.framework.TestCase;
import junit.framework.TestSuite;
import org.junit.Test;


public class AppTest extends TestCase
{

    public AppTest(String testName) {
        super(testName);
    }

    public void testApp() {
        App app = new App();
        assertNotNull(app);
    }

    public void testLib() {
        Lib lib = new Lib("hoge", 29);
        assertNotNull(lib);
    }

    @Test
    public void shouldAnswerWithTrue()
    {
        assertTrue( true );
    }
}

実行します.

% mvn clean package
% mvn exec:java

以下のようにメッセージが表示されたら成功です.

Hello, I am Hanako. I am 29 years old.

完成したライブラリをローカルリポジトリに登録します.ライブラリのプロジェクトmvn-lib直下から以下を実行します.

% mvn install

これでライブラリがローカルプロジェクトに登録されました.既に用意されているjarファイルがある場合,以下のコマンドでローカルリポジトリに追加することも可能です.

% mvn install:install-file
-Dfile=ライブラリファイルのパス (.../mvn-lib-1.0.jar)
-DgroupId=グループID (org.example.lib)
-DartifactId=アーティファクトID (mvn-lib)
-Dpackaging=パッケージング (jar)
-Dversion=バージョン (1.0)

ライブラリプロジェクトの利用

続いて,作成したライブラリを他のプロジェクトで利用します.ここでは「リモートリポジトリ(セントラル以外)の利用」で作成したrepository-sampleで利用します.

pom.xmlに作成したライブラリをdependency配下に追加します.

    <dependency>
      <groupId>org.example.lib</groupId>
      <artifactId>mvn-lib</artifactId>
      <version>1.0</version>
    </dependency>

最終的なpom.xmlは以下のようになります.

<?xml version="1.0" encoding="UTF-8"?>

<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/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>org.example</groupId>
  <artifactId>repository-sample</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>repository-sample</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>
  <repositories>
    <repository>
      <id>spring.org</id>
      <name>spring foundation repository</name>
      <url>http://repo.spring.io/release/</url>
    </repository>
  </repositories>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.aspectj</groupId>
      <artifactId>aspectjrt</artifactId>
      <version>1.9.19</version>
    </dependency>
    <dependency>
      <groupId>org.example.lib</groupId>
      <artifactId>mvn-lib</artifactId>
      <version>1.0</version>
    </dependency>
  </dependencies>

  <build>
    <plugins>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>3.1.0</version>
        <configuration>
          <mainClass>org.example.App</mainClass>
        </configuration>
      </plugin>
    </plugins>
    <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
      <plugins>
        <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
        <plugin>
          <artifactId>maven-clean-plugin</artifactId>
          <version>3.1.0</version>
        </plugin>
        <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
        <plugin>
          <artifactId>maven-resources-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-jar-plugin</artifactId>
          <version>3.0.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-install-plugin</artifactId>
          <version>2.5.2</version>
        </plugin>
        <plugin>
          <artifactId>maven-deploy-plugin</artifactId>
          <version>2.8.2</version>
        </plugin>
        <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
        <plugin>
          <artifactId>maven-site-plugin</artifactId>
          <version>3.7.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-project-info-reports-plugin</artifactId>
          <version>3.0.0</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
</project>

App.javaを編集します.

package org.example;

import org.example.lib.Lib;

public class App 
{
    public static void main( String[] args )
    {
        Lib lib = new Lib("Satoru", 32);
        System.out.println(lib.greeting());

    }
}

実行します.

% mvn clean package
% mvn exec:java

以下のようにメッセージが出力されたら成功です.

Hello, I am Satoru. I am 32 years old.
よかったらシェアしてね!
目次