Ditt maven-lager på GitHub
Utviklere kan laste opp biblioteket sitt til GitHub, som det har en spesiell site-maven-plugin-plugin for . La oss se på et eksempel på bruken:
<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>
La oss se hva som er skrevet her.
Opprettelsen av et midlertidig lokalt depot er uthevet i blått. Teknisk sett er det bare en mappe, men vi trenger at Maven behandler den som et eget depot.
Vi fremhevet med rødt lanseringen av maven-deploy-plugin plugin , der vi indikerte at det kompilerte biblioteket skulle plasseres i dette midlertidige depotet.
Og til slutt er site-maven-plugin-plugin-pluginen uthevet i grønt , som skal ta alle filene fra depotet og overføre dem til GitHub. Litt forklaring er nødvendig her. Alle parametere er delt inn i to grupper: hva du skal fylle og hvor du skal fylle.
Hva vi fyller inn:- outputDirectory - katalog hvor du kan hente filer for commit
- inkluderer - setter masken til filer som skal begås
- repositoryOwner - navnet på depoteieren på GitHub
- repositoryName - depotnavn
- branch - setter arkivgrenen på GitHub som den skal forplikte seg til
- melding - meldingen som vil bli lagt til ved forpliktelse
Du må også spesifisere pålogging og passord for depotet ditt i Maven setting.xml :
<settings>
<servers>
<server>
<id>github</id>
<username>[username]</username>
<password>[password]</password>
</server>
</servers>
</settings>
For å koble (bruke) et bibliotek fra et GitHub-depot til et annet prosjekt, må du spesifisere dette depotet i 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>
Etter det vil Maven forstå hvor biblioteket skal hentes fra.
- [navn-prosjekt] er navnet på prosjektet, i vårt tilfelle SuperLibrary
- [brukernavn] er påloggingen på GitHub, i eksemplet er det codegym-bruker
Pakke sammenstillingen inn i et Docker-bilde
Vi lever i en ny tid, når prosjekter som følge av monteringen kan plasseres i Maven-lageret, eller kanskje i docker-lager.
For å få Maven og Docker venner, trenger vi plugin-modulen docker-maven-plugin . Ikke noe komplisert:
<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>
Uthevet i blått er punktet der vi la til målbyggingen i pakkefasen av bygget. Den kan kalles med kommandoen mvn docker:build .
DockerDirectory- taggen spesifiserer mappen der Dockerfilen er plassert. Og navnet på bildet angis ved hjelp av imageName- taggen .
Hvis prosjektet er pakket i en jar-fil, vil docker-filen se omtrent slik ut:
FROM java:11
EXPOSE 8080
ADD /target/demo.jar demo.jar
ENTRYPOINT ["java","-jar","demo.jar"]
Hvis du pakker en nettapplikasjon, må du kanskje legge til Tomcat:
FROM tomcat8
ADD sample.war ${CATALINA_HOME}/webapps/ROOT.war
CMD ${CATALINA_HOME}/bin/catalina.sh run
GO TO FULL VERSION