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;[email protected]
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.