Apache IVY - Resolver

I resolver vengono utilizzati per trovare le posizioni da cui scaricare una libreria. Un risolutore di dipendenze gestisce anche attività comuni. Ivy fornisce due tipi di resolver.

  • Composite - Un risolutore che utilizza altri risolutori per svolgere i propri compiti.

  • Standard - Un resolver esegue le attività richieste.

Resolver standard

La tabella seguente elenca i resolver standard e il loro utilizzo.

Sr.No. Nome (tipo) e descrizione
1

IvyRep (Standard)

Individua i file Ivy su ivyrep e gli artefatti su ibiblio.
2

IBiblio (Standard)

Individua artefatti su ibiblio.
3

BinTray (Standard)

Individua gli artefatti su bintray.
4

Packager (Standard)

Individua i file Ivy e le istruzioni di pacchettizzazione tramite URL, crea artefatti utilizzando le istruzioni.
5

FileSystem (Standard)

Individua i file e gli artefatti Ivy sul file system locale.
6

URL (Standard)

Individua i file e gli artefatti Ivy nei repository a cui è possibile accedere utilizzando gli URL.
7

MirroredURL (Standard)

Individua i file e gli artefatti Ivy sui repository a cui è possibile accedere utilizzando gli URL da un elenco mirror.
8

VFS (Standard)

Individua i file e gli artefatti Ivy nei repository a cui è possibile accedere utilizzando Apache Commons VFS.
9

SSH (Standard)

Individua i file e gli artefatti Ivy sui repository a cui è possibile accedere tramite SSH.
10

SFTP (Standard)

Individua i file e gli artefatti Ivy sui repository a cui è possibile accedere tramite SFTP.
11

Jar (Standard)

Individua i file e gli artefatti Ivy sui repository all'interno di un jar.
12

Chain (Composite)

Delega la ricerca a una catena di sub-risolutori.
13

Dual (Composite)

Delega la ricerca a un risolutore e gli artefatti a un altro.
14

OBR (Standard)

Risolvi i moduli come bundle OSGi elencati da un OSGi obr.xml.
15

Eclipse updatesite (Standard)

Risolvi i moduli come bundle OSGi che sono ospitati su un sito di aggiornamento di Eclipse.
16

OSGi-agg (Composite)

Delega la ricerca a una catena di sub-resolver che supportano i bundle OSGi.

Creiamo Tester.java, build.xml e ivy.xml in un nuovo progetto sotto E: > ivy2cartella simile a quella descritta nel capitolo IVY - Risolvi attività . Crea una cartella delle impostazioni inE: > ivy2. Crea ivysettings.xml nella cartella delle impostazioni.

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <property name = "build.dir" value = "build"/>
   <property name = "base.dir" value = ""/>
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
   </target>
   <target name="compile" depends="resolve" description="Compile">
      <mkdir dir="build/classes" />
      <javac srcdir="src" destdir="build/classes">
         <classpath refid="new.classpath" />
      </javac>
   </target>
</project>

ivy.xml

<?xml version="1.0" encoding="ISO-8859-1"?>
<ivy-module version="2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:noNamespaceSchemaLocation="http://ant.apache.org/ivy/schemas/ivy.xsd">
   <info organisation="org.apache" module="chained-resolvers"/>
   <dependencies>
      <dependency org="commons-lang" name="commons-lang" rev="2.6" conf="default"/>
      <dependency org="com.tutorialspoint" name="test" rev="1.0"/>
   </dependencies>
</ivy-module>

Qui abbiamo aggiunto due dipendenze, una della libreria commons-lang e un'altra come test che abbiamo pubblicato nel capitolo IVY - Publish Task .

ivysettings.xml

<ivysettings>
   <settings defaultResolver="multiresolver"/>
   <resolvers>
      <chain name="multiresolver">
         <filesystem name="libraries">
            <artifact pattern="${ivy.settings.dir}/repository/[artifact]-[revision].[ext]"/>
         </filesystem>
         <ibiblio name="ibiblio" m2compatible="true"/>
      </chain>
   </resolvers>
</ivysettings>

Qui abbiamo aggiunto creato un risolutore composito usando il risolutore a catena che ha due risolutori, una librerie con nome per individuare le librerie sul repository locale e una denominata ibiblio sul repository pubblico maven.

Costruire il progetto

Poiché abbiamo tutti i file pronti. Vai alla console. Navigare versoE: > ivy2 cartella ed eseguire il comando ant.

E:\ivy > ant

Ivy entrerà in azione, risolvendo le dipendenze, vedrai il seguente risultato.

Buildfile: E:\ivy2\build.xml

resolve:
[ivy:resolve] :: Apache Ivy 2.5.0 - 20191020104435 :: https://ant.apache.org/ivy
/ ::
[ivy:resolve] :: loading settings :: url = jar:file:/E:/Apache/apache-ant-1.9.14
/lib/ivy-2.5.0.jar!/org/apache/ivy/core/settings/ivysettings.xml
[ivy:resolve] :: resolving dependencies :: org.apache#chained-resolvers;working@
Acer-PC
[ivy:resolve]   confs: [default]
[ivy:resolve]   found commons-lang#commons-lang;2.6 in public
[ivy:resolve]   found com.tutorialspoint#test;1.0 in local
[ivy:resolve]   found junit#junit;3.8.1 in public
[ivy:resolve] downloading C:\Users\Acer\.ivy2\local\com.tutorialspoint\test\1.0\
jars\application.jar ...
[ivy:resolve] .. (1kB)
[ivy:resolve] .. (0kB)
[ivy:resolve]   [SUCCESSFUL ] com.tutorialspoint#test;1.0!application.jar (13ms)

[ivy:resolve] :: resolution report :: resolve 1085ms :: artifacts dl 22ms
      ---------------------------------------------------------------------
      |                  |            modules            ||   artifacts   |
      |       conf       | number| search|dwnlded|evicted|| number|dwnlded|
      ---------------------------------------------------------------------
      |      default     |   3   |   3   |   1   |   0   ||   5   |   1   |
      ---------------------------------------------------------------------

BUILD SUCCESSFUL
Total time: 9 seconds

Nei log puoi verificare che abbiamo utilizzato risolutori di repository sia locali che pubblici.