Ang iyong maven repository sa GitHub
Maaaring i-upload ng mga developer ang kanilang library sa GitHub, kung saan mayroon itong espesyal na site-maven-plugin plugin . Tingnan natin ang isang halimbawa ng paggamit nito:
<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>
Tingnan natin kung ano ang nakasulat dito.
Ang paglikha ng isang pansamantalang lokal na imbakan ay naka-highlight sa asul. Sa teknikal, ito ay isang folder lamang, ngunit kailangan namin ng Maven na ituring ito bilang isang hiwalay na imbakan.
Na-highlight namin sa pula ang paglulunsad ng maven-deploy-plugin plugin , kung saan ipinahiwatig namin na ang pinagsama-samang library ay dapat ilagay sa pansamantalang repositoryong ito.
At sa wakas, ang site-maven-plugin plugin ay naka-highlight sa berde , na dapat kunin ang lahat ng mga file mula sa repository at i-commit ang mga ito sa GitHub. Ang ilang paliwanag ay kailangan dito. Ang lahat ng mga parameter ay nahahati sa dalawang grupo: kung ano ang pupunan at kung saan pupunan.
Ano ang pinupunan namin:- outputDirectory - direktoryo kung saan kukuha ng mga file para sa commit
- kasama - nagtatakda ng mask ng mga file na gagawin
- repositoryOwner - ang pangalan ng may-ari ng repository sa GitHub
- repositoryName - pangalan ng repository
- branch - itinatakda ang sangay ng repositoryo sa GitHub kung saan iko-commit
- mensahe - ang mensahe na idadagdag kapag gumawa
Kailangan mo ring tukuyin ang login at password para sa iyong repository sa Maven setting.xml :
<settings>
<servers>
<server>
<id>github</id>
<username>[username]</username>
<password>[password]</password>
</server>
</servers>
</settings>
Upang kumonekta (gumamit) ng isang library mula sa isang GitHub repository sa isa pang proyekto, kailangan mong tukuyin ang repository na ito sa iyong 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>
Pagkatapos nito, mauunawaan ni Maven kung saan kukuha ng library.
- [name-project] ay ang pangalan ng proyekto, sa aming kaso SuperLibrary
- [username] ay ang login sa GitHub, sa halimbawa ito ay codegym-user
Pag-pack ng pagpupulong sa isang imahe ng Docker
Nabubuhay tayo sa isang bagong panahon, kung kailan ang mga proyekto bilang resulta ng pagpupulong ay maaaring ilagay sa repositoryo ng Maven, o marahil sa imbakan ng docker.
Upang maging magkaibigan sina Maven at Docker, kailangan namin ang docker-maven-plugin plugin . Walang kumplikado:
<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>
Naka-highlight sa asul ang punto kung saan idinagdag namin ang bulid ng layunin sa yugto ng package ng build. Maaari itong tawagan gamit ang mvn docker:build command .
Tinutukoy ng tag ng dockerDirectory ang folder kung saan matatagpuan ang Dockerfile. At ang pangalan ng larawan ay itinakda gamit ang imageName tag .
Kung ang proyekto ay nakabalot sa isang jar file, ang docker file ay magiging ganito ang hitsura:
FROM java:11
EXPOSE 8080
ADD /target/demo.jar demo.jar
ENTRYPOINT ["java","-jar","demo.jar"]
Kung nag-iimpake ka ng isang web application, maaaring kailanganin mong magdagdag ng Tomcat:
FROM tomcat8
ADD sample.war ${CATALINA_HOME}/webapps/ROOT.war
CMD ${CATALINA_HOME}/bin/catalina.sh run
GO TO FULL VERSION