अपाचे आईवीवाई - त्वरित गाइड

अपाचे आइवी एक बहुत ही लोकप्रिय और बहुत शक्तिशाली निर्भरता प्रबंधन उपकरण है जिसका उपयोग एएनटी आधारित परियोजनाओं में उसी तरह से निर्भरता को प्रबंधित करने के लिए किया जाता है, कैसे अपाचे मावेन निर्भरता का प्रबंधन करता है।

Apache Ivy Apache ANT आधारित है, समान डिज़ाइन सिद्धांतों का अनुसरण करता है, Apache ANT का एक उपप्रकार है और Apache ANT समुदाय द्वारा सक्रिय रूप से प्रबंधित और समर्थित है।

विशेषताएं

निम्नलिखित अपाचे आइवी की महत्वपूर्ण विशेषताएं हैं।

  • ANT Based- Apache Ivy ANT आधारित परियोजनाओं के लिए एक निर्भरता प्रबंधन क्षमता प्रदान करता है। साथ ही इसका उपयोग करना बहुत सरल है।

  • Dependency Reports - Apache Ivy html में निर्भरता ग्राफ के साथ-साथ रिपोर्ट प्रारूप में प्रिंट करने के लिए विकल्प प्रदान करता है।

  • Non-intrusive- अपाचे आइवी वितरण के हिस्से के रूप में कोई प्रतिबंध नहीं लगाता है। यहां तक ​​कि बिल्ड फाइलें भी अपाचे आइवी पर निर्भर नहीं हैं।

  • Highly Flexible - अपाचे आइवी कई डिफ़ॉल्ट कॉन्फ़िगरेशन प्रदान करता है और आवश्यकता के अनुसार बहुत आसानी से कॉन्फ़िगर किया जा सकता है।

  • Extendible- अपाचे आइवी को आसानी से बढ़ाया जा सकता है। आप अपने स्वयं के भंडार, संघर्ष रिज़ॉल्वर और नवीनतम रणनीति को परिभाषित कर सकते हैं।

  • Performance- Apache Ivy प्रदर्शन के लिए बनाया गया है। यह पहले से डाउनलोड लाइब्रेरी का कैश रखता है। अन्य रिपॉजिटरी में देखने की तुलना में निर्भरता को हल करने के लिए सबसे पहले स्थानीय रिपोजिटरी में दिखता है।

  • Transitive Dependencies - अपाचे आइवी स्वचालित रूप से सकर्मक निर्भरता का प्रबंधन करता है यदि एक परियोजना या पुस्तकालय अन्य पुस्तकालय पर निर्भर करता है जिसे किसी अन्य पुस्तकालय की आवश्यकता हो सकती है।

  • Maven Repository- अपाचे आइवी मावेन रिपॉजिटरी सम्मेलनों के समान सम्मेलनों का अनुसरण करता है। अपाचे आइवी मावेन ग्लोबल रिपॉजिटरी का उपयोग करके निर्भरता को हल कर सकता है।

  • Maven 2 POMs- अपाचे आइवी मॉड्यूल विवरणक के रूप में मावेन 2 पीओएम पढ़ सकते हैं, आइवी को मॉड्यूल विवरणक के रूप में सेट कर सकते हैं। इस प्रकार मौजूदा परियोजनाओं को आईवीवाई प्रबंधित परियोजनाओं में स्थानांतरित करना आसान हो जाता है।

  • Publishing - अपाचे आइवी आपकी परियोजना को प्रकाशित करने के लिए समर्थन प्रदान करता है और बहु-परियोजना पर्यावरण परिनियोजन प्रक्रिया को सरल करता है।

  • Free to Use - अपाचे आइवी खुला स्रोत है और उपयोग करने के लिए स्वतंत्र है।

  • Documentation - अपाचे आइवी में सीखने के लिए बहुत विस्तृत दस्तावेज और ट्यूटोरियल उपलब्ध हैं।

Apache Ivy को केवल आवश्यकता के रूप में जावा और ANT को आपकी मशीन पर स्थापित किया जाना चाहिए।

अपाचे चींटी को अपाचे सॉफ्टवेयर लाइसेंस के तहत वितरित किया जाता है, जो पूर्णतया खुला स्रोत लाइसेंस है जो ओपन सोर्स पहल द्वारा प्रमाणित है।

इसके पूर्ण-स्रोत कोड, वर्ग फ़ाइलों और प्रलेखन सहित नवीनतम अपाचे चींटी संस्करण को पाया जा सकता है http://ant.apache.org.

अपाचे चींटी को स्थापित करना

यह माना जाता है कि आपने अपने कंप्यूटर पर जावा डेवलपमेंट किट (JDK) पहले ही डाउनलोड और इंस्टॉल कर लिया है। यदि नहीं, तो कृपया यहां दिए गए निर्देशों का पालन करें ।

  • सुनिश्चित करें कि JAVA_HOME पर्यावरण चर उस फ़ोल्डर पर सेट है जहाँ आपका JDK स्थापित है।

  • से बायनेरिज़ डाउनलोड करें https://ant.apache.org

  • ज़िप फ़ाइल को सुविधाजनक स्थान c: \ folder में अनज़िप करें। Winzip, winRAR, 7-zip या इसी तरह के औजारों का उपयोग करना।

  • नामक एक नया वातावरण चर बनाएँ ANT_HOME इस मामले में चींटी स्थापना फ़ोल्डर को इंगित करता है c:\apache-ant-1.9.14-bin फ़ोल्डर।

  • पथ चींटी पर्यावरण चर के लिए अपाचे चींटी बैच फ़ाइल के लिए पथ लागू करें। हमारे मामले में यह होगाc:\apache-ant-1.9.14-bin\bin फ़ोल्डर।

अपाचे चींटी स्थापना का सत्यापन

अपने कंप्यूटर पर अपाचे चींटी की सफल स्थापना को सत्यापित करने के लिए, अपने कमांड प्रॉम्प्ट पर चींटी टाइप करें।

आपको इसके समान आउटपुट देखना चाहिए -

C:\>ant -version
Apache Ant(TM) version 1.9.14 compiled on March 12 2019

यदि आप उपरोक्त आउटपुट नहीं देखते हैं, तो कृपया पुष्टि करें कि आपने स्थापना चरणों का ठीक से पालन किया है।

अपाचे आइवी को स्थापित करना

  • से बायनेरिज़ डाउनलोड करें https://ant.apache.org/ivy

  • ज़िप फ़ाइल को सुविधाजनक स्थान c: \ folder में अनज़िप करें। Winzip, winRAR, 7-zip या इसी तरह के औजारों का उपयोग करना।

  • Ivy-2.5.0.jar को कॉपी करें c:\apache-ant-1.9.14-bin/lib फ़ोल्डर।

अपाचे आइवी इंस्टॉलेशन का सत्यापन

अपने कंप्यूटर पर Apache Ivy की सफल स्थापना को सत्यापित करने के लिए, एक फ़ोल्डर E:> आइवी में निम्न फ़ाइल बनाएँ।

<project name="test ivy installation" 
   default="test" xmlns:ivy="antlib:org.apache.ivy.ant">
   <target name="test" description="Test ivy installation">
      <ivy:settings />
   </target>
</project>

आपको इसके समान आउटपुट देखना चाहिए -

C:\>ant
Buildfile: E:\ivy\build.xml
test:
BUILD SUCCESSFUL
Total time: 2 seconds

ग्रहण लगाना

यह ट्यूटोरियल ग्रहण आईडीई के साथ चींटी के एकीकरण को भी कवर करता है। इसलिए, यदि आपने पहले से ग्रहण स्थापित नहीं किया है, तो कृपया ग्रहण डाउनलोड और स्थापित करें

ग्रहण स्थापित करने के लिए -

  • Www.eclipse.org से नवीनतम ग्रहण बायनेरिज़ डाउनलोड करें

  • ग्रहण बायनेरिज़ को सुविधाजनक स्थान पर अनज़िप करें, सी: \ फ़ोल्डर

  • C: \ eclipse \ eclipse.exe से ग्रहण को चलाएँ

आइवी शब्दावली को समझने के लिए निम्न उदाहरण आइवीएक्सएक्सएक्सएमएल पर विचार करें।

<?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="com.tutorialspoint" module="ivy-test" status="integration">
   </info>
   <dependencies>
      <dependency org="commons-lang" name="commons-lang" rev="2.6" />
   </dependencies>
</ivy-module>

आइवी शर्तें

आइवी इको-सिस्टम की महत्वपूर्ण शर्तें निम्नलिखित हैं।

  • Organisation- जैसा कि नाम से पता चलता है, यह कंपनी, व्यक्तिगत डेवलपर या टीम के नाम को संदर्भित करता है जो परियोजना या पुस्तकालय बनाता है। उदाहरण के लिए, com.tutorialspoint।

  • Module- जैसा कि नाम से पता चलता है, यह पुन: प्रयोज्य इकाई या मॉड्यूल को संदर्भित करता है। एक मॉड्यूल में आमतौर पर एक संस्करण जुड़ा होता है। उदाहरण के लिए कॉमन्स-लैंग, या आइवी-टेस्ट आदि।

  • Module Descriptor- मॉड्यूल डिस्क्रिप्टर ivy.xml फ़ाइल को संदर्भित करता है जो एक मॉड्यूल का वर्णन करता है। एक मॉड्यूल विवरणक में पहचानकर्ता (ओआरजी, नाम, शाखा और संस्करण), प्रकाशित कलाकृतियां, कॉन्फ़िगरेशन और निर्भरताएं होती हैं।

  • Artifact- आर्टिफ़ैक्ट एक फ़ाइल के रूप में संदर्भित करने योग्य है। उदाहरण के लिए, एक जार फ़ाइल। कलाकारी प्रकार की हो सकती है: ज़िप, gz आदि जार, स्रोत जार, जावदोक जार एक मॉड्यूल की विभिन्न कलाकृतियां हैं।

  • Type - टाइप आर्टिफिशियल कैटेगरी जैसे जार, वार, src, doc आदि की पहचान करता है।

  • Artifact file name extension - कलाकृतियों का विस्तार जैसे .जार, ज़िप, .gz आदि।

  • Module Revision - मॉड्यूल या इसके संस्करण संख्या का एक अद्वितीय संशोधन संख्या।

  • Status of Revision- संशोधन की स्थिति संशोधन की स्थिरता को इंगित करती है। स्थिति के महत्वपूर्ण मूल्य निम्नलिखित हैं -

    • integration - लगातार विकास, रात का निर्माण आदि का प्रतिनिधित्व करता है।

    • milestone - एक वितरण का प्रतिनिधित्व करता है लेकिन अंतिम रूप से नहीं।

    • release - एक प्रमुख संस्करण का परीक्षण और पूरा किया गया प्रतिनिधित्व करता है।

  • Repository - मावेन रिपॉजिटरी के समान, रिपॉजिटरी एक वितरण साइट का प्रतिनिधित्व करती है जहां आइवी लाइब्रेरी, कलाकृतियों, मॉड्यूल आदि की खोज कर सकती है। रिपॉजिटरी सार्वजनिक, निजी या साझा की जा सकती है।

  • Ivy Settings- अपाचे आइवी मावेन सिद्धांतों का पालन करता है और बहुत सारे डिफ़ॉल्ट कॉन्फ़िगरेशन के साथ आता है। Ivysettings.xml फ़ाइल को परिभाषित करके डिफ़ॉल्ट सेटिंग्स को ओवरराइड किया जा सकता है।

अपाचे आइवी मावेन सिद्धांतों का पालन करता है और बहुत सारे डिफ़ॉल्ट कॉन्फ़िगरेशन के साथ आता है। Ivysettings.xml फ़ाइल को परिभाषित करके डिफ़ॉल्ट सेटिंग्स को ओवरराइड किया जा सकता है।

<ivysettings>
	<properties file="${ivy.settings.dir}/ivysettings-file.properties" /> <settings defaultCache="${cache.dir}" defaultResolver="ibiblio" checkUpToDate="false" />
	<resolvers>
		<ibiblio name="ibiblio" />
		<filesystem name="internal">
			<ivy pattern="${repository.dir}/[module]/ivy-[revision].xml" /> <artifact pattern="${repository.dir}/[module]/[artifact]-[revision].[ext]" />
		</filesystem>
	</resolvers>
	<modules>
		<module organisation="tutorialspoint" name=".*" resolver="internal" />
	</modules>
</ivysettings>

आइवी सेटिंग्स फ़ाइल का टैग

आइवी सेटिंग फ़ाइल के महत्वपूर्ण टैग निम्नलिखित हैं।

  • property- आइवी वेरिएबल सेट करने के लिए। कार्डिनैलिटी: 0..n.

  • properties- गुण फ़ाइल का उपयोग कर एक आइवी चर सेट करने के लिए। कार्डिनैलिटी: 0..n.

  • settings- डिफ़ॉल्ट मानों के साथ आइवी को कॉन्फ़िगर करने के लिए। कार्डिनैलिटी: 0..1

  • include- एक और सेटिंग फ़ाइल शामिल करने के लिए। कार्डिनैलिटी: 0..n.

  • classpath- प्लग-इन लोड करने के लिए उपयोग किए जाने वाले क्लासपाथ में एक स्थान जोड़ने के लिए। कार्डिनैलिटी: 0..n.

  • typedef- आइवी में नए प्रकार को परिभाषित करने के लिए। कार्डिनैलिटी: 0..n.

  • lock-strategies- लॉक रणनीतियों को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • caches- रिपोजिटरी कैश मैनेजर को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • latest-strategies- नवीनतम रणनीतियों को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • parsers- मॉड्यूल डिस्क्रिप्टर पार्सर को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • version-matchers- नए संस्करण मिलान को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • triggers- आइवी घटनाओं पर ट्रिगर रजिस्टर करने के लिए। कार्डिनैलिटी: 0..1

  • namespaces- नए नामस्थान को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • macrodef- एक नए मैक्रो रिज़ॉल्वर को परिभाषित करने के लिए। कार्डिनैलिटी: 0..n.

  • resolvers- निर्भरता रिज़ॉल्वर को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • conflict-managers- संघर्ष प्रबंधकों को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • modules- मॉड्यूल और निर्भरता रिज़ॉल्वर के बीच नियमों को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • outputters- उपलब्ध रिपोर्ट आउटपुट की सूची को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

  • statuses- उपलब्ध स्थितियों की सूची को परिभाषित करने के लिए। कार्डिनैलिटी: 0..1

IvyDE Apache द्वारा प्रदान किया गया एक ग्रहण प्लगइन है। IvyDE स्थापित करने के लिए, ग्रहण शुरू करें और मदद> नया सॉफ़्टवेयर स्थापित करने के लिए नेविगेट करें। यह उपलब्ध सॉफ्टवेयर्स विंडो को प्रदर्शित करता है। IvyDE अपडेट साइट दर्ज करें http://www.apache.org/dist/ant/ivyde/updatesite/और एंटर की दबाएं। यह निम्न प्लगइन्स प्रदर्शित करता है।

अगला क्लिक करें और आप निम्न स्क्रीन देखेंगे।

यदि आप प्लगइन स्थापित करते समय किसी भी त्रुटि का सामना कर रहे हैं तो बस प्रक्रिया को पुनरारंभ करें। सफल स्थापना के बाद, आप eclipe में प्लगइन देखेंगे।

अब आप ग्रहण और आइवी का उपयोग करके निर्भरता प्रबंधन कर सकते हैं।

रिज़ॉल्यूशन टास्क का उपयोग ivy.xml में वर्णित निर्भरता को हल करने के लिए किया जाता है, डाउनलोड करें और उन्हें आइवी कैश में डाल दें।

चलिए सबसे पहले एक java फाइल बनाते हैं Tester.java in E: > ivy > src > com > tutorialspoint फ़ोल्डर जो चींटी परियोजना के लिए स्रोत फ़ोल्डर के रूप में कार्य करेगा।

Application.java

package com.tutorialspoint;
import org.apache.commons.lang.StringUtils;
public class Application {
   public static void main(String[] args) {
      String string = StringUtils.upperCase("Ivy Beginner Guide");
      System.out.println(string);
   }
}

इसके बाद के संस्करण वर्ग अपनी कक्षा StringUtils का उपयोग करने के लिए अपाचे कॉमन्स लैंग लाइब्रेरी का उपयोग कर रहा है। आइवी को इस लाइब्रेरी को डाउनलोड करना चाहिए और इस तरह इसे आइवीएक्सएक्सएमएल में निर्भरता अनुभाग के तहत परिभाषित किया जाना चाहिए। इसके बाद ivy.xml बनाया जाता है E: > ivy फ़ोल्डर।

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="com.tutorialspoint"
      module="test"
      status="integration">
   </info>
   <dependencies>
      <dependency org="org.apache.commons" name="commons-lang3" rev="3.9"/>
   </dependencies>
</ivy-module>

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • ivy-module - आइवी वर्जन, नेमस्पेस आदि की पहचान करने के लिए रूट एलिमेंट

  • info - एक अद्वितीय इकाई के रूप में परियोजना की पहचान करने के लिए तत्व।

    • organisation - संगठन का नाम

    • module - मॉड्यूल का नाम

    • status - रिलीज, एकीकरण या मील का पत्थर जैसी स्थिति।

  • dependencies - तत्व पर निर्भरता टैग के रूप में परियोजना निर्भरता को शामिल करने के लिए निम्नलिखित गुण हैं।

    • org - निर्भरता के संगठन का नाम

    • name - निर्भरता का नाम।

    • rev - निर्भरता का संस्करण।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
   </target>
</project<

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • project - आइवी के लिए प्रोजेक्ट नाम, डिफ़ॉल्ट कार्य नाम स्थान आदि की पहचान करने के लिए मूल तत्व।

  • target- एक नया कार्य और उसका विवरण बनाने के लिए लक्ष्य तत्व। इसमें आइवी का हल कार्य होता है। जब चींटी परियोजना का निर्माण करती है, तो वह आइवी संकल्प कार्य चलाती है, जो तब आइवी का उपयोग करके निर्भरता को हल करता है।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

Buildfile: E:\ivy\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 :: com.tutorialspoint#test;working@Acer-
PC
[ivy:resolve]   confs: [default]
[ivy:resolve]   found commons-lang#commons-lang;2.6 in public
[ivy:resolve]   found junit#junit;3.8.1 in public
[ivy:resolve] :: resolution report :: resolve 375ms :: artifacts dl 79ms
      ---------------------------------------------------------------------
      |                  |            modules            ||   artifacts   |
      |       conf       | number| search|dwnlded|evicted|| number|dwnlded|
      ---------------------------------------------------------------------
      |      default     |   2   |   2   |   0   |   0   ||   4   |   0   |
      ---------------------------------------------------------------------
[ivy:retrieve] :: retrieving :: com.tutorialspoint#test [sync]
[ivy:retrieve]  confs: [default]
[ivy:retrieve]  0 artifacts copied, 2 already retrieved (0kB/101ms)
BUILD SUCCESSFUL
Total time: 1 second
E:\ivy>

आउटपुट का समाधान करें

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • conf - कॉन्फ़िगरेशन, हमारे मामले में हम डिफ़ॉल्ट कॉन्फ़िगरेशन का उपयोग कर रहे हैं।

  • modules - मॉड्यूल, डाउनलोड किए गए मॉड्यूल आदि की कुल संख्या को इंगित करता है।

  • artifacts - कलाकृतियों की कुल संख्या, डाउनलोड की गई कलाकृतियों आदि को इंगित करता है।

आप आइवी कैश के डिफ़ॉल्ट स्थान में डाउनलोड की गई फ़ाइलों को सत्यापित कर सकते हैं ${ivy.default.ivy.user.dir} > .ivy2 > cacheफ़ोल्डर। और $ {ivy.default.ivy.user.dir} डिफ़ॉल्ट उपयोगकर्ता घर से है: $ HOME।

इंस्टॉल कार्य का उपयोग एक रिवाल्वर में एक मॉड्यूल और इसकी निर्भरता को स्थापित करने के लिए किया जाता है। इसका उपयोग तब किया जाता है जब किसी सार्वजनिक कलाकृति को डाउनलोड करना और निजी भंडार में उपयोग करना होता है। डिफ़ॉल्ट रूप से, एक उपयोगकर्ता स्थानीय रिपॉजिटरी उसका निजी भंडार है और $ {ivy.default.ivy.user.dir} / स्थानीय में मौजूद है।

आईवीवाई में बताए अनुसार Tester.java, build.xml और ivy.xml बनाएं - टास्क चैप्टर को हल करें ।

Ivy स्थापित कार्य का उपयोग करने के लिए build.xml अद्यतन करें।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
   </target>
   <target name="install" description="install dependencies">
      <ivy:install organisation="commons-lang" module="commons-lang" 
         revision="2.6" transitive="true" overwrite="false" 
         from="public" to="local" />
   </target>
</project>

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • organisation - संगठन का नाम।

  • module - प्रोजेक्ट का मॉड्यूल नाम।

  • revision - परियोजना का संस्करण।

  • from - भंडार प्रकार से।

  • to - रिपोजिटरी प्रकार के लिए।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant install

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

E:\ivy > ant install
Buildfile: E:\ivy\build.xml
install:
[ivy:install] :: Apache Ivy 2.5.0 - 20191020104435 :: https://ant.apache.org/ivy
/ ::
[ivy:install] :: 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:install] :: installing commons-lang#commons-lang;2.6 ::
[ivy:install] :: resolving dependencies ::
[ivy:install]   found commons-lang#commons-lang;2.6 in public
[ivy:install]   found junit#junit;3.8.1 in public
[ivy:install] :: downloading artifacts to cache ::
[ivy:install] :: installing in local ::
[ivy:install]   published commons-lang to C:\Users\Acer\.ivy2\local\commons-lang
\commons-lang\2.6.part\sources\commons-lang.jar
[ivy:install]   published commons-lang to C:\Users\Acer\.ivy2\local\commons-lang
\commons-lang\2.6.part\jars\commons-lang.jar
[ivy:install]   published commons-lang to C:\Users\Acer\.ivy2\local\commons-lang
\commons-lang\2.6.part\javadocs\commons-lang.jar
[ivy:install]   published ivy to C:\Users\Acer\.ivy2\local\commons-lang\commons-
lang\2.6.part\ivys\ivy.xml
[ivy:install]   publish committed: moved C:\Users\Acer\.ivy2\local\commons-lang\
commons-lang\2.6.part
[ivy:install]           to C:\Users\Acer\.ivy2\local\commons-lang\commons-lang\2
.6
[ivy:install]   published junit to C:\Users\Acer\.ivy2\local\junit\junit\3.8.1.p
art\jars\junit.jar
[ivy:install]   published ivy to C:\Users\Acer\.ivy2\local\junit\junit\3.8.1.par
t\ivys\ivy.xml
[ivy:install]   publish committed: moved C:\Users\Acer\.ivy2\local\junit\junit\3
.8.1.part
[ivy:install]           to C:\Users\Acer\.ivy2\local\junit\junit\3.8.1
[ivy:install] :: install resolution report ::
[ivy:install] :: resolution report :: resolve 0ms :: artifacts dl 21ms
      ---------------------------------------------------------------------
      |                  |            modules            ||   artifacts   |
      |       conf       | number| search|dwnlded|evicted|| number|dwnlded|
      ---------------------------------------------------------------------
      |      default     |   2   |   0   |   0   |   0   ||   4   |   0   |
      ---------------------------------------------------------------------
BUILD SUCCESSFUL
Total time: 43 seconds

आप डाउनलोड की गई फ़ाइलों को आइवी कैश के डिफ़ॉल्ट स्थानीय भंडार स्थान में सत्यापित कर सकते हैं ${ivy.default.ivy.user.dir} > .ivy2 > local निर्देशिका।

परियोजना कार्यक्षेत्र में एक निर्दिष्ट स्थान पर निर्भरता को हल करने के लिए पुनः प्राप्त कार्य का उपयोग किया जाता है।

आईवीवाई में बताए अनुसार Tester.java, build.xml और ivy.xml बनाएं - टास्क चैप्टर को हल करें ।

Ivy पुनर्प्राप्त कार्य का उपयोग करने के लिए build.xml अद्यतन करें।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
      <ivy:retrieve sync="true" type="jar" />
   </target>
</project>

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • sync - सिंक सही यह सुनिश्चित करता है कि काम करने योग्य निर्देशिका अद्यतित है और किसी भी अतिरिक्त फ़ाइल को हटा दिया जाता है।

  • type- टाइप निर्देश आइवी को केवल निर्दिष्ट प्रकार की कलाकृतियों जैसे जार को कॉपी करने के लिए निर्देशित करता है। स्रोत जार, जावाडॉक जार को नजरअंदाज कर दिया जाएगा। सोर्स जार के लिए टाइप src या सोर्स और javadoc जार के लिए doc या बंडल है।

कार्यों को पुनः प्राप्त करें डिफ़ॉल्ट रूप से प्रोजेक्ट की कार्यशील निर्देशिका में हल की गई निर्भरता को कॉपी करता है और पैटर्न विशेषता का उपयोग करके बदला जा सकता है।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

Buildfile: E:\ivy\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 :: com.tutorialspoint#test;working@Acer-
PC
[ivy:resolve]   confs: [default]
[ivy:resolve]   found commons-lang#commons-lang;2.6 in public
[ivy:resolve]   found junit#junit;3.8.1 in public
[ivy:resolve] :: resolution report :: resolve 316ms :: artifacts dl 18ms
      ---------------------------------------------------------------------
      |                  |            modules            ||   artifacts   |
      |       conf       | number| search|dwnlded|evicted|| number|dwnlded|
      ---------------------------------------------------------------------
      |      default     |   2   |   2   |   0   |   0   ||   4   |   0   |
      ---------------------------------------------------------------------
[ivy:retrieve] :: retrieving :: com.tutorialspoint#test [sync]
[ivy:retrieve]  confs: [default]
[ivy:retrieve]  0 artifacts copied, 2 already retrieved (0kB/2756ms)
BUILD SUCCESSFUL
Total time: 31 seconds

आप डाउनलोड की गई फ़ाइलों को प्रोजेक्ट लिबरी निर्देशिका में सत्यापित कर सकते हैं।

कैशपथ कार्य का उपयोग एएनटी क्लासपाथ बनाने के लिए किया जाता है जिसमें कैश में मौजूद हल की गई कलाकृतियां होती हैं। चूंकि ANT को java फ़ाइलों को संकलित करने के लिए jars को classpath करने की आवश्यकता होती है, Ivy cachepath classpath बनाता है।

आईवीवाई में बताए अनुसार Tester.java, build.xml और ivy.xml बनाएं - टास्क चैप्टर को हल करें ।

Ivy पुनर्प्राप्त कार्य का उपयोग करने के लिए build.xml अद्यतन करें।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
      <ivy:cachepath pathid="new.classpath" />
   </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>

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • pathid - क्लासपाथ की आईडी जहां कैश्ड जार मौजूद हैं।

कार्यों को पुनः प्राप्त करें डिफ़ॉल्ट रूप से प्रोजेक्ट की कार्यशील निर्देशिका में हल की गई निर्भरता को कॉपी करता है और पैटर्न विशेषता का उपयोग करके बदला जा सकता है।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant compile

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

Buildfile: E:\ivy\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 :: com.tutorialspoint#test;working@Acer-
PC
[ivy:resolve]   confs: [default]
[ivy:resolve]   found commons-lang#commons-lang;2.6 in public
[ivy:resolve]   found junit#junit;3.8.1 in public
[ivy:resolve] :: resolution report :: resolve 2314ms :: artifacts dl 15ms
      ---------------------------------------------------------------------
      |                  |            modules            ||   artifacts   |
      |       conf       | number| search|dwnlded|evicted|| number|dwnlded|
      ---------------------------------------------------------------------
      |      default     |   2   |   2   |   0   |   0   ||   4   |   0   |
      ---------------------------------------------------------------------
compile:
   [javac] E:\ivy\build.xml:13: warning: 'includeantruntime' was not set, defau
lting to build.sysclasspath=last; set to false for repeatable builds
   [javac] Compiling 1 source file to E:\ivy\build\classes
BUILD SUCCESSFUL
Total time: 3 seconds

आप प्रोजेक्ट बिल्ड निर्देशिका में संकलित वर्ग फ़ाइल को सत्यापित कर सकते हैं।

प्रकाशित कार्य का उपयोग वर्तमान कलाकृतियों और इसके सुलझी हुई वर्णनकर्ता फ़ाइलों को प्रकाशित करने के लिए रिपॉजिटरी में प्रकाशित करने के लिए किया जाता है।

आईवीवाई में बताए अनुसार Tester.java, build.xml और ivy.xml बनाएं - टास्क चैप्टर को हल करें ।

Ivy प्रकाशित कार्य का उपयोग करने के लिए build.xml अद्यतन करें। पहले हम एक जार फ़ाइल बनाएंगे और फिर उसे प्रकाशित करेंगे।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <property name = "build.dir" value = "build"/>
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
   </target>
   <target name = "jar">
      <jar destfile = "${build.dir}/lib/application.jar"
         basedir = "${build.dir}/classes"> <manifest> <attribute name = "Main-Class" value = "com.tutorialspoint.Application"/> </manifest> </jar> </target> <target name="publish" depends="jar"> <ivy:resolve /> <ivy:publish resolver="local" pubrevision="1.0" overwrite="true"> <artifacts pattern="${build.dir}/lib/[artifact].[ext]" />
      </ivy:publish>   
   </target>
</project>

निम्नलिखित महत्वपूर्ण शब्द हैं।

  • resolver - प्रकाशन के लिए इस्तेमाल की जाने वाली रिवाल्वर।

  • pattern - कलाकृतियों का पता लगाने के लिए पैटर्न।

यहां प्रकाशित कार्य टास्क पहले जार का निर्माण करते हैं, फिर निर्भरता को हल करते हैं, जानकारी सेट करते हैं और फिर स्थानीय रिपॉजिटरी में कलाकृतियों को प्रकाशित करते हैं।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant publish

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

E:\ivy > ant publish
Buildfile: E:\ivy\build.xml
jar:
publish:
[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 :: com.tutorialspoint#test;1.0.0
[ivy:resolve]   confs: [default]
[ivy:resolve]   found commons-lang#commons-lang;2.6 in public
[ivy:resolve]   found junit#junit;3.8.1 in public
[ivy:resolve] :: resolution report :: resolve 121ms :: artifacts dl 15ms
      ---------------------------------------------------------------------
      |                  |            modules            ||   artifacts   |
      |       conf       | number| search|dwnlded|evicted|| number|dwnlded|
      ---------------------------------------------------------------------
      |      default     |   2   |   2   |   0   |   0   ||   4   |   0   |
      ---------------------------------------------------------------------
[ivy:publish] :: publishing :: com.tutorialspoint#test
[ivy:publish]   published application to C:\Users\Acer\.ivy2\local\com.tutorials
point\test\1.0\jars\application.jar
[ivy:publish]   published ivy to C:\Users\Acer\.ivy2\local\com.tutorialspoint\te
st\1.0\ivys\ivy.xml
BUILD SUCCESSFUL
Total time: 1 second

आप स्थानीय रिपॉजिटरी में प्रकाशित आइवी कलाकृतियों को सत्यापित कर सकते हैं।

जानकारी कार्य का उपयोग किसी फ़ाइल में ivy विशिष्ट जानकारी सेट करने के लिए किया जाता है और इसका उपयोग बिना किसी निर्भरता समाधान के किया जा सकता है।

आईवीवाई में बताए अनुसार Tester.java, build.xml और ivy.xml बनाएं - टास्क चैप्टर को हल करें ।

Ivy प्रकाशित कार्य का उपयोग करने के लिए build.xml अद्यतन करें। पहले हम एक जार फ़ाइल बनाएंगे और फिर उसे प्रकाशित करेंगे। कार्य प्रकाशित करने से पहले, हमने जानकारी कार्य का उपयोग करके आवश्यक आइवी जानकारी सेट की है।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <property name = "build.dir" value = "build"/>
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
   </target>
   <target name = "jar">
      <jar destfile = "${build.dir}/lib/application.jar" basedir = "${build.dir}/classes">      
         <manifest>
            <attribute name = "Main-Class" value = "com.tutorialspoint.Application"/>
         </manifest>
      </jar>
   </target>
   <target name="publish" depends="jar">
      <ivy:info file="ivy.xml" />
      <ivy:publish resolver="local" pubrevision="1.0" overwrite="true">
         <artifacts pattern="${build.dir}/lib/[artifact].[ext]" />
      </ivy:publish>   
   </target>
</project>

यहाँ प्रकाशित कार्य टास्क पहले जार का निर्माण करते हैं, फिर आइवी: इंफो टास्क का उपयोग करके जानकारी सेट करते हैं और फिर स्थानीय रिपॉजिटरी में आर्टवर्क प्रकाशित करते हैं।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant publish

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

Buildfile: E:\ivy\build.xml
jar:
publish:
 [ivy:info] :: Apache Ivy 2.5.0 - 20191020104435 :: https://ant.apache.org/ivy/
::
 [ivy:info] :: loading settings :: url = jar:file:/E:/Apache/apache-ant-1.9.14/l
ib/ivy-2.5.0.jar!/org/apache/ivy/core/settings/ivysettings.xml
[ivy:publish] :: publishing :: com.tutorialspoint#test
[ivy:publish]   published application to C:\Users\Acer\.ivy2\local\com.tutorials
point\test\1.0\jars\application.jar
[ivy:publish]   published ivy to C:\Users\Acer\.ivy2\local\com.tutorialspoint\te
st\1.0\ivys\ivy.xml
BUILD SUCCESSFUL
Total time: 0 seconds

अगर हम इंफो टास्क नहीं डालेंगे तो पब्लिश टास्क नहीं चलेगा। नीचे दिए गए build.xml का उपयोग करें और संगठन की अनुपस्थिति और इतने पर त्रुटि को देखें।

build.xml

<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant">
   <property name = "build.dir" value = "build"/>
   <target name="resolve" description="resolve dependencies">
      <ivy:resolve />
   </target>
   <target name = "jar">
      <jar destfile = "${build.dir}/lib/application.jar"
         basedir = "${build.dir}/classes"> <manifest> <attribute name = "Main-Class" value = "com.tutorialspoint.Application"/> </manifest> </jar> </target> <target name="publish" depends="jar"> <ivy:publish resolver="local" pubrevision="1.0" overwrite="true"> <artifacts pattern="${build.dir}/lib/[artifact].[ext]" />
      </ivy:publish>   
   </target>
</project>

पर जाए E: > ivy फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant publish

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

Buildfile: E:\ivy\build.xml
jar:
publish:
[ivy:publish] :: Apache Ivy 2.5.0 - 20191020104435 :: https://ant.apache.org/ivy
/ ::
[ivy:publish] :: 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
BUILD FAILED
E:\ivy\build.xml:28: no organisation provided for ivy publish task: It can eithe
r be set explicitly via the attribute 'organisation' or via 'ivy.organisation' p
roperty or a prior call to <resolve/>
Total time: 3 seconds

रिज़ॉल्वर का उपयोग उन स्थानों को खोजने के लिए किया जाता है जहाँ से लाइब्रेरी डाउनलोड की जानी है। एक निर्भरता रिज़ॉल्वर सामान्य कार्यों को भी संभालती है। आइवी दो प्रकार के रिज़ॉल्वर प्रदान करता है।

  • Composite - एक रिज़ॉल्वर जो अपने कार्यों को करने के लिए अन्य रिज़ॉल्वर का उपयोग करता है।

  • Standard - एक रिज़ॉल्वर आवश्यक कार्य करता है।

मानक रिज़ॉल्वर

निम्न तालिका मानक रिज़ॉल्वर और उनके उपयोग को सूचीबद्ध करती है।

अनु क्रमांक। नाम (प्रकार) और विवरण
1

IvyRep (Standard)

आइवीइल पर आइवी फाइलें और ibiblio पर कलाकृतियों का पता लगाता है।
2

IBiblio (Standard)

Ibiblio पर कलाकृतियों का पता लगाता है।
3

BinTray (Standard)

बिंट्रे पर कलाकृतियों का पता लगाता है।
4

Packager (Standard)

आइवी फ़ाइलों और पैकेजिंग निर्देशों को यूआरएल के माध्यम से पता लगाता है, निर्देशों का उपयोग करके कलाकृतियों का निर्माण करता है।
5

FileSystem (Standard)

स्थानीय फ़ाइल सिस्टम पर आइवी फ़ाइलों और कलाकृतियों का पता लगाता है।
6

URL (Standard)

रिपॉजिटरी पर आईवी फाइलें और कलाकृतियां ढूंढता है, जिन्हें यूआरएल का उपयोग करके एक्सेस किया जा सकता है।
7

MirroredURL (Standard)

रिपॉजिटरी पर आईवी फाइलें और कलाकृतियां ढूंढती हैं, जिन्हें मिरर सूची से URL का उपयोग करके एक्सेस किया जा सकता है।
8

VFS (Standard)

रिपॉजिटरी पर आईवी फाइलों और कलाकृतियों का पता लगाता है, जिन्हें अपाचे कॉमन्स वीएफएस का उपयोग करके एक्सेस किया जा सकता है।
9

SSH (Standard)

रिपॉजिटरी पर आइवी फाइलों और कलाकृतियों का पता लगाता है, जिन्हें एसएसएच का उपयोग करके एक्सेस किया जा सकता है।
10

SFTP (Standard)

रिपॉजिटरी पर आईवी फाइलों और कलाकृतियों का पता लगाता है, जिन्हें एसएफटीपी का उपयोग करके एक्सेस किया जा सकता है।
1 1

Jar (Standard)

जार के भीतर रिपॉजिटरी पर आईवी फाइलें और कलाकृतियों का पता लगाता है।
12

Chain (Composite)

उप रिज़ॉल्वर की एक श्रृंखला के लिए खोज प्रतिनिधि।
13

Dual (Composite)

एक रिज़ॉल्वर और कलाकृतियों की खोज को दूसरे तक पहुँचाता है।
14

OBR (Standard)

OSGi obr.xml द्वारा सूचीबद्ध OSGi बंडलों के रूप में मॉड्यूल का समाधान करें।
15

Eclipse updatesite (Standard)

OSGi बंडलों के रूप में मॉड्यूल को हल करें जो एक ग्रहण अपडेट साइट पर होस्ट किए गए हैं।
16

OSGi-agg (Composite)

OSGi बंडलों का समर्थन करने वाले उप रिज़ॉल्वर की एक श्रृंखला के लिए खोज को हटाता है।

आइए एक नए प्रोजेक्ट के तहत Tester.java, build.xml और ivy.xml बनाएं E: > ivy2IVY में वर्णित के समान फ़ोल्डर - टास्क अध्याय को हल करें । के तहत एक सेटिंग्स फ़ोल्डर बनाएँE: > ivy2। सेटिंग फ़ोल्डर में ivysettings.xml बनाएँ।

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>

यहाँ हमने दो निर्भरताएँ जोड़ी हैं, एक कॉमन्स-लैंग लाइब्रेरी और दूसरा टेस्ट के रूप में जिसे हमने IVY - पब्लिश टास्क चैप्टर में प्रकाशित किया है ।

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>

यहां हमने श्रृंखला रिज़ॉल्वर का उपयोग करके एक संयुक्त रिज़ॉल्वर बनाया है जिसमें दो रिज़ॉल्वर हैं, जिनमें से एक का नाम स्थानीय रिपॉजिटरी पर काम करने वालों का पता लगाने के लिए पुस्तकालयों और एक का नाम मैबैन पब्लिक रिपॉज़िटरी पर ibiblio है।

परियोजना का निर्माण

जैसा कि हमने सभी फाइलें तैयार कर ली हैं। बस सांत्वना जाओ। पर जाएE: > ivy2 फ़ोल्डर और चींटी कमांड चलाएँ।

E:\ivy > ant

आइवी कार्रवाई में आएगा, निर्भरता को हल करते हुए, आप निम्नलिखित परिणाम देखेंगे।

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

लॉग में आप यह सत्यापित कर सकते हैं कि हमने स्थानीय और सार्वजनिक रिपॉजिटरी रिसोल्वर दोनों का उपयोग किया है।

एक स्थानीय रिपॉजिटरी एक उपयोगकर्ता का एक निजी रिपॉजिटरी है। यदि कोई उपयोगकर्ता किसी ऐसे पुस्तकालय का उपयोग कर रहा है, जिसका संस्करण अन्य स्थानों पर बदल दिया गया है और उसमें परिवर्तन हो रहे हैं, तो यह बहुत उपयोगी है। स्थानीय रिपॉजिटरी के मामले में, आइवी पाए जाने पर स्थानीय में मौजूद लाइब्रेरी का उपयोग करेगा और सार्वजनिक या साझा रिपॉजिटरी में नहीं दिखेगा।

अकरण स्थान

डिफ़ॉल्ट रूप से, स्थानीय रिपॉजिटरी $ {ivy.default.ivy.user.dir} / स्थानीय फ़ोल्डर में मौजूद है। यदि आप इसे बदलना चाहते हैं, तो चींटी फ़ाइल में ivy.local.default.root चर का उपयोग करें।

build.xml

<target name="resolve">
   <property name="ivy.local.default.root" value="/opt/ivy/repository/local"/>
   <ivy:resolve />
</target>

आइवी पैटर्न और विरूपण साक्ष्य पैटर्न जैसी अन्य संपत्तियों को निम्नानुसार भी अनुकूलित किया जा सकता है -

build.xml

<target name="resolve">
   <property name="ivy.local.default.root" value="/opt/ivy/repository/local"/>
   <property name="ivy.local.default.ivy.pattern" value="[module]/[revision]/ivy.xml"/>
   <property name="ivy.local.default.artifact.pattern" value="[module]/[revision]/[artifact].[ext]"/>
   <ivy:resolve />
</target>

ओवरराइडिंग ivysettings चूक

डिफ़ॉल्ट रूप से ivy का ivyettings.xml में मौजूद विन्यास ivy.jar में है।

ivysettings.xml

<ivysettings>
   <settings defaultResolver="default"/>
   <include url="${ivy.default.settings.dir}/ivysettings-public.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-shared.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-local.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-main-chain.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-default-chain.xml"/>
</ivysettings>

स्थानीय रिपॉजिटरी सेटिंग को ओवरराइड करने के लिए, ivysettings-local.xml की सामग्री को अपडेट करें।

ivysettings-local.xml

<ivysettings>
   <property name="ivy.local.default.root" value="${ivy.default.ivy.user.dir}/local" override="false"/>
   <property name="ivy.local.default.ivy.pattern" value="[organisation]/[module]/[revision]/[type]s/[artifact].[ext]" override="false"/>
   <property name="ivy.local.default.artifact.pattern" value="[organisation]/[module]/[revision]/[type]s/[artifact].[ext]" override="false"/>
   <resolvers>
      <filesystem name="local">
         <ivy pattern="${ivy.local.default.root}/${ivy.local.default.ivy.pattern}" />
         <artifact pattern="${ivy.local.default.root}/${ivy.local.default.artifact.pattern}" />
      </filesystem>
   </resolvers>
</ivysettings>

एक साझा रिपॉजिटरी एक टीम के स्तर का एक साझा रिपॉजिटरी है। संगठनों में अतिप्रश्न होना बहुत आम है।

अकरण स्थान

डिफ़ॉल्ट रूप से, साझा रिपॉजिटरी $ {ivy.default.ivy.user.dir} / साझा फ़ोल्डर में मौजूद है। यदि आप इसे बदलना चाहते हैं, तो चींटी फ़ाइल में ivy.sared.default.root चर का उपयोग करें।

build.xml

<target name="resolve">
   <property name="ivy.shared.default.root" value="/opt/ivy/repository/shared"/>
   <ivy:resolve />
</target>

आइवी पैटर्न और विरूपण साक्ष्य पैटर्न जैसी अन्य संपत्तियों को निम्नानुसार भी अनुकूलित किया जा सकता है -

build.xml

<target name="resolve">
   <property name="ivy.shared.default.root" value="/opt/ivy/repository/shared"/>
   <property name="ivy.shared.default.ivy.pattern" value="[organisation]/[module]/[revision]/ivy.xml"/>
   <property name="ivy.shared.default.artifact.pattern" value="[organisation]/[module]/[revision]/[artifact].[ext]"/>
   <ivy:resolve />
</target>

ओवरराइडिंग ivysettings चूक

डिफ़ॉल्ट रूप से ivy का ivyettings.xml में मौजूद विन्यास ivy.jar में है।

ivysettings.xml

<ivysettings>
   <settings defaultResolver="default"/>
   <include url="${ivy.default.settings.dir}/ivysettings-public.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-shared.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-local.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-main-chain.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-default-chain.xml"/>
</ivysettings>

साझा रिपॉजिटरी सेटिंग को ओवरराइड करने के लिए, ivysettings-shared.xml की सामग्री को अपडेट करें।

ivysettings-shared.xml

<ivysettings>
   <property name="ivy.shared.default.root" value="${ivy.default.ivy.user.dir}/shared" override="false"/> <property name="ivy.shared.default.ivy.pattern" value="[organisation]/[module]/[revision]/[type]s/[artifact].[ext]" override="false"/> <property name="ivy.shared.default.artifact.pattern" value="[organisation]/[module]/[revision]/[type]s/[artifact].[ext]" override="false"/> <resolvers> <filesystem name="shared"> <ivy pattern="${ivy.shared.default.root}/${ivy.shared.default.ivy.pattern}" /> <artifact pattern="${ivy.shared.default.root}/${ivy.shared.default.artifact.pattern}" />
      </filesystem>
   </resolvers>
</ivysettings>

एक सार्वजनिक रिपॉजिटरी एक रिपॉजिटरी है जो इंटरनेट का उपयोग करके सुलभ है और तीसरे पक्ष के मॉड्यूल हैं। डिफ़ॉल्ट रूप से ibiblio m2 संगत मोड में सार्वजनिक रिपॉजिटरी है। इसे मावेन 2 सार्वजनिक भंडार के रूप में भी जाना जाता है।

ओवरराइडिंग ivysettings चूक

डिफ़ॉल्ट रूप से ivy का ivyettings.xml में मौजूद विन्यास ivy.jar में है।

ivysettings.xml

<ivysettings>
   <settings defaultResolver="default"/>
   <include url="${ivy.default.settings.dir}/ivysettings-public.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-shared.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-local.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-main-chain.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-default-chain.xml"/>
</ivysettings>

सार्वजनिक रिपॉजिटरी सेटिंग को ओवरराइड करने के लिए, ivysettings-public.xml की सामग्री को अपडेट करें या अपने प्रोजेक्ट के फ़ोल्डर की सेटिंग में ivysettings.xml बनाएं।

ivysettings.xml

<ivysettings>
   <settings defaultResolver="default"/>
   <include url="http://customserver/ivy/ivysettings-public.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-shared.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-local.xml"/>
   <include url="${ivy.default.settings.dir}/ivysettings-main-chain.xml"/> <include url="${ivy.default.settings.dir}/ivysettings-default-chain.xml"/>
</ivysettings>

डिफ़ॉल्ट ivysetting-public.xml सामग्री को अपडेट करें।

Original - ivysetting-public.xml

<ivysettings>
   <resolvers>
      <ibiblio name="public" m2compatible="true"/>
   </resolvers>
</ivysettings>

Updated - ivysetting-public.xml

<ivysettings>
   <resolvers>
      <filesystem name="public">
         <ivy pattern="/path/to/my/public/rep/[organisation]/[module]/ivy-[revision].xml" />
         <artifact pattern="/path/to/my/public/rep/[organisation]/[module]/[artifact]-[revision].[ext]" />
      </filesystem>
   </resolvers>
</ivysettings>