Ditt maven-förråd på GitHub
Utvecklare kan ladda upp sitt bibliotek till GitHub, för vilket det har en speciell site-maven-plugin-plugin . Låt oss titta på ett exempel på dess användning:
<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>
Låt oss se vad som står här.
Skapandet av ett tillfälligt lokalt arkiv är markerat i blått. Tekniskt sett är det bara en mapp, men vi behöver Maven för att behandla den som ett separat arkiv.
Vi markerade med rött lanseringen av maven-deploy-plugin plugin , där vi indikerade att det kompilerade biblioteket skulle placeras i detta temporära arkiv.
Och slutligen är insticksprogrammet site-maven-plugin markerat i grönt , vilket bör ta alla filer från förvaret och överföra dem till GitHub. Här behövs en förklaring. Alla parametrar är indelade i två grupper: vad som ska fyllas och var ska fyllas.
Vad vi fyller i:- outputDirectory - katalog där man kan hämta filer för commit
- inkluderar - ställer in masken för filer som ska begås
- repositoryOwner - namnet på arkivets ägare på GitHub
- repositoryName - arkivnamn
- branch - ställer in förvarsgrenen på GitHub som den ska commit
- meddelande - meddelandet som kommer att läggas till vid bekräftelse
Du måste också ange inloggning och lösenord för ditt arkiv i Maven setting.xml :
<settings>
<servers>
<server>
<id>github</id>
<username>[username]</username>
<password>[password]</password>
</server>
</servers>
</settings>
För att ansluta (använda) ett bibliotek från ett GitHub-förråd till ett annat projekt, måste du ange detta förråd i din 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>
Efter det kommer Maven att förstå var man kan hämta biblioteket ifrån.
- [namn-projekt] är namnet på projektet, i vårt fall SuperLibrary
- [användarnamn] är inloggningen på GitHub, i exemplet är det codegym-user
Packar sammansättningen till en Docker-bild
Vi lever i en ny tid, då projekt som ett resultat av monteringen kan placeras i Maven-förvaret, eller kanske i hamnarlager.
För att göra Maven och Docker vänner behöver vi plugin-programmet docker-maven-plugin . Inget komplicerat:
<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>
Markerad i blått är punkten där vi lade till målbyggnaden i paketfasen av bygget. Det kan anropas med kommandot mvn docker:build .
DockerDirectory- taggen anger mappen där Dockerfilen finns. Och namnet på bilden ställs in med taggen imageName .
Om projektet är paketerat i en jar-fil kommer docker-filen att se ut ungefär så här:
FROM java:11
EXPOSE 8080
ADD /target/demo.jar demo.jar
ENTRYPOINT ["java","-jar","demo.jar"]
Om du paketerar en webbapplikation kan du behöva lägga till Tomcat:
FROM tomcat8
ADD sample.war ${CATALINA_HOME}/webapps/ROOT.war
CMD ${CATALINA_HOME}/bin/catalina.sh run
GO TO FULL VERSION