गिटहब पर आपका मावेन भंडार
डेवलपर अपनी लाइब्रेरी को GitHub पर अपलोड कर सकते हैं, जिसके लिए इसमें एक विशेष साइट-मावेन-प्लगइन प्लगइन है । आइए इसके उपयोग का एक उदाहरण देखें:
<project>
<properties>
<github.global.server>github</github.global.server>
<github.maven-plugin>0.9</github.maven-plugin>
</properties>
<distributionManagement>
<repository>
<id>internal.repo</id>
<name>Temporary Staging Repository</name>
<url>file://${project.build.directory}/mvn-repo</url>
</repository>
</distributionManagement>
<build>
<plugins>
<plugin>
<artifactId>maven-deploy-plugin</artifactId>
<version>2.8.1</version>
<configuration>
<altDeploymentRepository>
internal.repo::default::file://${project.build.directory}/mvn-repo
</altDeploymentRepository>
</configuration>
</plugin>
<plugin>
<groupId>com.github.github</groupId>
<artifactId>site-maven-plugin</artifactId>
<version>${github.maven-plugin}</version>
<configuration>
<message>Maven artifacts for ${project.version}</message>
<noJekyll>true</noJekyll>
<outputDirectory>${project.build.directory}/mvn-repo</outputDirectory>
<branch>refs/heads/mvn-repo</branch>
<includes>**/*</includes>
<repositoryName>SuperLibrary</repositoryName>
<repositoryOwner>codegymu-student</repositoryOwner>
</configuration>
<executions>
<execution>
<goals>
<goal>site</goal>
</goals>
<phase>deploy</phase>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
आइए देखें कि यहां क्या लिखा है।
एक अस्थायी स्थानीय भंडार का निर्माण नीले रंग में हाइलाइट किया गया है। तकनीकी रूप से यह सिर्फ एक फ़ोल्डर है, लेकिन हमें इसे एक अलग रिपॉजिटरी के रूप में मानने के लिए मावेन की जरूरत है।
हमने मावेन-तैनाती-प्लगइन प्लगइन के लॉन्च को लाल रंग में हाइलाइट किया , जहां हमने संकेत दिया कि संकलित लाइब्रेरी को इस अस्थायी रिपॉजिटरी में रखा जाना चाहिए।
और अंत में, साइट-मावेन-प्लगइन प्लगइन को हरे रंग में हाइलाइट किया गया है , जिसे सभी फाइलों को रिपॉजिटरी से लेना चाहिए और उन्हें गिटहब में जमा करना चाहिए। यहाँ कुछ स्पष्टीकरण की आवश्यकता है। सभी मापदंडों को दो समूहों में बांटा गया है: क्या भरना है और कहां भरना है।
हम क्या भरते हैं:- आउटपुट डायरेक्टरी - निर्देशिका जहां प्रतिबद्ध करने के लिए फाइलें प्राप्त करें
- शामिल - प्रतिबद्ध करने के लिए फाइलों का मुखौटा सेट करता है
- रिपॉजिटरीऑनर - गिटहब पर रिपॉजिटरी के मालिक का नाम
- रिपॉजिटरीनाम - रिपॉजिटरी का नाम
- शाखा - गिटहब पर रिपोजिटरी शाखा सेट करता है जिसके लिए प्रतिबद्ध होना चाहिए
- संदेश - वह संदेश जो कमिट करते समय जोड़ा जाएगा
आपको Maven Setting.xml में अपनी रिपॉजिटरी के लिए लॉगिन और पासवर्ड निर्दिष्ट करने की आवश्यकता है :
<settings>
<servers>
<server>
<id>github</id>
<username>[username]</username>
<password>[password]</password>
</server>
</servers>
</settings>
एक GitHub रिपॉजिटरी से एक लाइब्रेरी को दूसरे प्रोजेक्ट से कनेक्ट (उपयोग) करने के लिए, आपको इस रिपॉजिटरी को अपने pom.xml में निर्दिष्ट करना होगा :
<repositories>
<repository>
<id>[name-project]-mvn-repo</id>
<url>https://raw.github.com/[username]/[name-project]/mvn-repo/</url>
<snapshots>
<enabled>true</enabled>
<updatePolicy>always</updatePolicy>
</snapshots>
</repository>
</repositories>
उसके बाद, मावेन समझ जाएगा कि लाइब्रेरी कहाँ से प्राप्त करें।
- [नाम-परियोजना] परियोजना का नाम है, हमारे मामले में सुपरलाइब्रेरी
- [उपयोगकर्ता नाम] गिटहब पर लॉगिन है, उदाहरण में यह जावारश-उपयोगकर्ता है
असेंबली को डॉकर छवि में पैक करना
हम एक नए समय में रहते हैं, जब असेंबली के परिणामस्वरूप परियोजनाओं को मेवेन रिपोजिटरी में रखा जा सकता है, या शायद डॉकर स्टोरेज में रखा जा सकता है।
मेवेन और डॉकर मित्र बनाने के लिए, हमें डॉकर-मेवेन-प्लगइन प्लगइन की आवश्यकता है । कुछ भी जटिल नहीं:
<build>
<plugins>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.4.10</version>
<configuration>
<dockerDirectory>${project.basedir}</dockerDirectory>
<imageName>codegym/${project.artifactId}</imageName>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
नीले रंग में हाइलाइट किया गया वह बिंदु है जहां हमने बिल्ड के पैकेज चरण में लक्ष्य को जोड़ा है। इसे mvn docker:build कमांड से कॉल किया जा सकता है ।
DockerDirectory टैग उस फ़ोल्डर को निर्दिष्ट करता है जहाँ Dockerfile स्थित है। और इमेज का नाम इमेजनेम टैग का उपयोग करके सेट किया गया है ।
यदि प्रोजेक्ट जार फ़ाइल में पैक किया गया है, तो डॉकटर फ़ाइल कुछ इस तरह दिखाई देगी:
FROM java:11
EXPOSE 8080
ADD /target/demo.jar demo.jar
ENTRYPOINT ["java","-jar","demo.jar"]
यदि आप एक वेब एप्लिकेशन की पैकेजिंग कर रहे हैं, तो आपको टॉमकैट जोड़ने की आवश्यकता हो सकती है:
FROM tomcat8
ADD sample.war ${CATALINA_HOME}/webapps/ROOT.war
CMD ${CATALINA_HOME}/bin/catalina.sh run
GO TO FULL VERSION