How to publish packages to gitlab package registry
Here in this article we will try to compile and build a package for maven project and push the artifacts to gitlab package registry.
Test Environment
Fedora 39 server
gitlab-ee 16.9.2
If you are interested in watching the video. Here is the YouTube video on the same step by step procedure outlined below.
Procedure
Step1: Ensure Gitlab and Gitlab runner installed
For this demo, please ensure that you have gitlab and gitlab runner installed or available for use. In my case i have got both the gitlab server and gitlab runner installed on the same machine for this demo purpose.
admin@fedres:~$ sudo gitlab-ctl status
run: alertmanager: (pid 1131) 0s; run: log: (pid 1116) 0s
run: gitaly: (pid 1083) 0s; run: log: (pid 1078) 0s
run: gitlab-exporter: (pid 1129) 0s; run: log: (pid 1119) 0s
run: gitlab-kas: (pid 1086) 0s; run: log: (pid 1082) 0s
run: gitlab-pages: (pid 1135) 0s; run: log: (pid 1122) 0s
run: gitlab-workhorse: (pid 1118) 0s; run: log: (pid 1102) 0s
run: logrotate: (pid 1101) 0s; run: log: (pid 1091) 0s
run: nginx: (pid 1093) 0s; run: log: (pid 1092) 0s
run: node-exporter: (pid 1130) 0s; run: log: (pid 1121) 0s
run: postgres-exporter: (pid 1132) 0s; run: log: (pid 1115) 0s
run: postgresql: (pid 1085) 0s; run: log: (pid 1080) 0s
run: prometheus: (pid 1134) 0s; run: log: (pid 1133) 0s
run: puma: (pid 1097) 0s; run: log: (pid 1089) 0s
run: redis: (pid 1081) 0s; run: log: (pid 1077) 0s
run: redis-exporter: (pid 1120) 0s; run: log: (pid 1114) 0s
run: sidekiq: (pid 1094) 0s; run: log: (pid 1087) 0s
admin@fedres:~$ sudo gitlab-runner status
Runtime platform arch=amd64 os=linux pid=1827 revision=b92ee590 version=17.4.0
gitlab-runner: Service is running
Step2: Ensure maven and jdk installed on runner
Here in this step we will be installing maven and java jdk package as shown below.
admin@fedres:~$ sudo dnf install maven java-17-openjdk-devel
Step3: Add the CA cert to java trust store cacerts on gitlab runner
If you have gitlab server running on secure port using self signed certificate. You need to trust the self sign certificate by adding it to the java trust store cacerts on gitlab runner so that the communication from gitlab runner to gitlab server while uploading the artifacts does not fail PKI cert trust issues.
admin@fedres:~$ sudo keytool -trustcacerts -keystore "/usr/lib/jvm/jre-17-openjdk/lib/security/cacerts" -storepass changeit -importcert -alias fedres.stack -file /home/admin/middleware/certs/fedres.stack.com.pem
NOTE: fedres.stack.com.pem is the self signed cert for my gitlab instance
Ensure that the trust certificate has been added to the cacerts.
admin@fedres:~$ keytool -list -cacerts | grep fedres
Enter keystore password: changeit
fedres.stack, 11-Oct-2024, trustedCertEntry,
Step4: Create a personal access token for gitlab registry access
In my case i have a user “dev” for which i am going to create a personal access token.
Go To – Your Profile – Preferences – Access Tokens and create you own personal access token.
Step5: Update maven settings with gitlab registry server details on gitlab runner
The default installation of maven generates a “settings.xml” file in “/etc/maven/”. We need to update the following file with the gitlab registry details as shown below. In the servers section, i have added the sub section “server” with id “gitlab-maven” with the username and the personal access token we just created in the last step.
admin@fedser:~$ cat /etc/maven/settings.xml
...
<servers>
<server>
<id>gitlab-maven</id>
<username>dev</username>
<password>glpat-PRvts5M7GVWF-RBvyQtN</password>
<configuration>
<authenticationInfo>
<userName>dev</userName>
<password>glpat-PRvts5M7GVWF-RBvyQtN</password>
</authenticationInfo>
</configuration>
</server>
</servers>
...
Step6: Create a blank project in your namespace
Here i am going to create a blank project name “hellomaven” as shown below.
Step7: Clone blank project
admin@fedres:~$ git clone git@fedres.stack.com:stack/hellomaven.git
admin@fedres:~/hellomaven$ git switch --create main
admin@fedres:~/hellomaven$ touch README.md
admin@fedres:~/hellomaven$ git add README.md
admin@fedres:~/hellomaven$ git commit -m "add README"
admin@fedres:~/hellomaven$ git push -u origin main
Step8: Create a maven archetype project
Here we are going to create a maven based archetype project by providing the necessary details as shown below.
admin@fedres:~/hellomaven$ mvn archetype:generate
...
Choose a number or apply filter (format: [groupId:]artifactId, case sensitive contains): 2189:
Choose org.apache.maven.archetypes:maven-archetype-quickstart version:
1: 1.0-alpha-1
2: 1.0-alpha-2
3: 1.0-alpha-3
4: 1.0-alpha-4
5: 1.0
6: 1.1
7: 1.3
8: 1.4
9: 1.5
Choose a number: 9:
[INFO] Using property: javaCompilerVersion = 17
[INFO] Using property: junitVersion = 5.11.0
Define value for property 'groupId': com.stack
Define value for property 'artifactId': hellomaven
Define value for property 'version' 1.0-SNAPSHOT:
Define value for property 'package' com.stack: com.stack
Confirm properties configuration:
javaCompilerVersion: 17
junitVersion: 5.11.0
groupId: com.stack
artifactId: hellomaven
version: 1.0-SNAPSHOT
package: com.stack
Y: Y
[INFO] ----------------------------------------------------------------------------
[INFO] Using following parameters for creating project from Archetype: maven-archetype-quickstart:1.5
[INFO] ----------------------------------------------------------------------------
[INFO] Parameter: groupId, Value: com.stack
[INFO] Parameter: artifactId, Value: hellomaven
[INFO] Parameter: version, Value: 1.0-SNAPSHOT
[INFO] Parameter: package, Value: com.stack
[INFO] Parameter: packageInPathFormat, Value: com/stack
[INFO] Parameter: junitVersion, Value: 5.11.0
[INFO] Parameter: package, Value: com.stack
[INFO] Parameter: groupId, Value: com.stack
[INFO] Parameter: artifactId, Value: hellomaven
[INFO] Parameter: javaCompilerVersion, Value: 17
[INFO] Parameter: version, Value: 1.0-SNAPSHOT
[WARNING] Don't override file /home/admin/hellomaven/hellomaven/src/main/java/com/stack
[WARNING] Don't override file /home/admin/hellomaven/hellomaven/src/test/java/com/stack
[WARNING] CP Don't override file /home/admin/hellomaven/hellomaven/.mvn
[INFO] Project created from Archetype in dir: /home/admin/hellomaven/hellomaven
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 01:17 min
[INFO] Finished at: 2024-10-15T17:14:19+05:30
[INFO] ------------------------------------------------------------------------
Move the content of hellomaven folder to the root hellomaven folder as shown below.
admin@fedres:~/hellomaven$ mv hellomaven/* .
admin@fedres:~/hellomaven$ rm -rf hellomaven
admin@fedres:~/hellomaven$ ls -ltr
total 4
-rw-r--r--. 1 admin admin 0 Oct 15 17:11 README.md
-rw-r--r--. 1 admin admin 3101 Oct 15 17:14 pom.xml
drwxr-xr-x. 4 admin admin 30 Oct 15 17:14 src
Step9: Update pom.xml with the gitlab registry endpoint in the project
Here in this step we will need to update our pom.xml with the repositories section and distrubitionManagement section as shown below. Maven will connect to the gitlab repository endpoint and upload the packages to the respective repositories for release and snapshot packages.
admin@fedres:~/hellomaven$ cat pom.xml
...
<repositories>
<repository>
<id>gitlab-maven</id>
<url>https://fedres.stack.com/api/v4/projects/21/packages/maven</url>
</repository>
</repositories>
<distributionManagement>
<repository>
<id>gitlab-maven</id>
<url>https://fedres.stack.com/api/v4/projects/21/packages/maven</url>
</repository>
<snapshotRepository>
<id>gitlab-maven</id>
<url>https://fedres.stack.com/api/v4/projects/21/packages/maven</url>
</snapshotRepository>
</distributionManagement>
Step10: Create a .gitlab-ci.yml as shown below
Here is our very basic gitlab cicd pipeline where in we will build the package, test it and publish it to the the gitlab artifacts registry when a commit is pushed to the main branch of the repository.
admin@fedres:~/hellomaven$ cat .gitlab-ci.yml
#image: maven:3.8.5-openjdk-17
#variables:
# MAVEN_CLI_OPTS: "-s .m2/settings.xml --batch-mode"
# MAVEN_OPTS: "-Dmaven.repo.local=.m2/repository"
#
#cache:
# paths:
# - .m2/repository/
# - target/
stages:
- build
- test
- publish
build:
stage: build
script:
- mvn compile
test:
stage: test
script:
- mvn test
publish:
stage: publish
script:
- mvn deploy
rules:
- if: $CI_COMMIT_BRANCH == "main"
Push the changes to your gitlab repository.
admin@fedres:~/hellomaven$ git add .
admin@fedres:~/hellomaven$ git commit -m "update maven project"
[main 8767b82] update maven project
4 files changed, 151 insertions(+)
create mode 100644 .gitlab-ci.yml
create mode 100644 pom.xml
create mode 100644 src/main/java/com/stack/App.java
create mode 100644 src/test/java/com/stack/AppTest.java
admin@fedres:~/hellomaven$ git push -u origin main
Enumerating objects: 16, done.
Counting objects: 100% (16/16), done.
Delta compression using up to 8 threads
Compressing objects: 100% (7/7), done.
Writing objects: 100% (15/15), 2.12 KiB | 2.12 MiB/s, done.
Total 15 (delta 0), reused 0 (delta 0), pack-reused 0 (from 0)
To fedres.stack.com:stack/hellomaven.git
833c815..8767b82 main -> main
branch 'main' set up to track 'origin/main'.
Step11: Validate the build artifacts
Once the changes are pushed to the main branch, gitlab cicd pipeline will trigger and execute our build, test and publish stages as shown below.
Now Go To – hellomaven project – Deploy – Package registry and you should be able to the see the artifacts that are pushed to gitlab registry.
Hope you enjoyed reading this article. Thank you..
Leave a Reply
You must be logged in to post a comment.