Merge pull request 'feat: enable building multiple almalinux releases' (#7) from neoloc/multirelease into master
All checks were successful
Deploy / build (push) Successful in 1m9s
All checks were successful
Deploy / build (push) Successful in 1m9s
Reviewed-on: https://git.query.consul/unkin/docker-almalinux-base/pulls/7
This commit is contained in:
commit
ded1f70b31
60
Makefile
60
Makefile
@ -1,33 +1,49 @@
|
|||||||
# Get the current Git commit hash
|
# Variables
|
||||||
GIT_COMMIT := $(shell git rev-parse --short HEAD)
|
GIT_COMMIT := $(shell git rev-parse --short HEAD)
|
||||||
|
|
||||||
# Get the current date in YYYYMMDD format
|
|
||||||
DATE_TAG := $(shell date +%Y%m%d)
|
DATE_TAG := $(shell date +%Y%m%d)
|
||||||
|
IMAGE_NAME := almalinux
|
||||||
# Set the Docker image name and repository information
|
|
||||||
IMAGE_NAME := almalinux8
|
|
||||||
REGISTRY := git.query.consul
|
REGISTRY := git.query.consul
|
||||||
OWNER := unkin
|
OWNER := unkin
|
||||||
|
|
||||||
# Build the Docker image (without tags)
|
# List of releases (directories under ./release)
|
||||||
build:
|
RELEASES := $(shell find release -mindepth 1 -maxdepth 1 -type d -exec basename {} \;)
|
||||||
docker build --network=host -t $(REGISTRY)/$(OWNER)/$(IMAGE_NAME) .
|
|
||||||
|
|
||||||
# Tag the Docker image with the Git commit hash, the date, and 'latest'
|
# Default target (build all images)
|
||||||
tag:
|
default: build-all
|
||||||
docker tag $(REGISTRY)/$(OWNER)/$(IMAGE_NAME) $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):$(GIT_COMMIT)
|
|
||||||
docker tag $(REGISTRY)/$(OWNER)/$(IMAGE_NAME) $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):$(DATE_TAG)
|
|
||||||
docker tag $(REGISTRY)/$(OWNER)/$(IMAGE_NAME) $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):latest
|
|
||||||
|
|
||||||
# Push the Docker image to a repository with all tags
|
# List all available releases
|
||||||
push: tag
|
list:
|
||||||
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):$(GIT_COMMIT)
|
@echo "Available releases:"
|
||||||
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):$(DATE_TAG)
|
@echo $(RELEASES) | tr ' ' '\n'
|
||||||
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):latest
|
|
||||||
|
|
||||||
# Clean up dangling Docker images
|
# Build all releases
|
||||||
|
build: $(addprefix build-,$(RELEASES))
|
||||||
|
|
||||||
|
# Tag all releases
|
||||||
|
tag: $(addprefix tag-,$(RELEASES))
|
||||||
|
|
||||||
|
# Push all releases
|
||||||
|
push: $(addprefix push-,$(RELEASES))
|
||||||
|
|
||||||
|
# Clean dangling images
|
||||||
clean:
|
clean:
|
||||||
docker image prune -f
|
docker image prune -f
|
||||||
|
|
||||||
# Default target
|
# Build a specific release
|
||||||
default: build
|
build-%:
|
||||||
|
$(info Building AlmaLinux $* Docker image)
|
||||||
|
docker build --network=host -t $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$* -f release/$*/Dockerfile release/$*
|
||||||
|
|
||||||
|
# Tag a specific release
|
||||||
|
tag-%:
|
||||||
|
$(info Tagging AlmaLinux $* Docker image)
|
||||||
|
docker tag $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$* $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$*:$(GIT_COMMIT)
|
||||||
|
docker tag $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$* $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$*:$(DATE_TAG)
|
||||||
|
docker tag $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$* $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$*:latest
|
||||||
|
|
||||||
|
# Push a specific release
|
||||||
|
push-%: tag-%
|
||||||
|
$(info Pushing AlmaLinux $* Docker image)
|
||||||
|
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$*:$(GIT_COMMIT)
|
||||||
|
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$*:$(DATE_TAG)
|
||||||
|
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME)$*:latest
|
||||||
|
|||||||
24
release/9/Dockerfile
Normal file
24
release/9/Dockerfile
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
# Start with the base AlmaLinux 9.4 image
|
||||||
|
FROM almalinux:9.4
|
||||||
|
|
||||||
|
# Remove existing repos and copy custom repo files into the container
|
||||||
|
RUN rm -rf /etc/yum.repos.d/*.repo
|
||||||
|
|
||||||
|
# Copy from the local context into the container
|
||||||
|
COPY files/*.repo /etc/yum.repos.d/
|
||||||
|
|
||||||
|
# Install ca-certs
|
||||||
|
RUN curl -k -o internal-ca-certificates.rpm https://git.query.consul/unkin/-/packages/rpm/internal-ca-certificates/20240825-1.el8/files/756 && \
|
||||||
|
rpm -i internal-ca-certificates.rpm
|
||||||
|
|
||||||
|
# Clean and update the repository cache
|
||||||
|
RUN dnf clean all && \
|
||||||
|
dnf makecache
|
||||||
|
|
||||||
|
# Update the system and install required packages
|
||||||
|
RUN dnf update -y && \
|
||||||
|
dnf install -y curl-minimal git
|
||||||
|
|
||||||
|
# Cleanup
|
||||||
|
RUN dnf clean all && \
|
||||||
|
rm -rf /var/cache/dnf
|
||||||
4
release/9/files/appstream.repo
Normal file
4
release/9/files/appstream.repo
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[appstream]
|
||||||
|
name=appstream repository
|
||||||
|
baseurl=https://edgecache.query.consul/almalinux/9.4/AppStream/x86_64/os
|
||||||
|
gpgkey=http://edgecache.query.consul/almalinux/RPM-GPG-KEY-AlmaLinux-9
|
||||||
4
release/9/files/baseos.repo
Normal file
4
release/9/files/baseos.repo
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[baseos]
|
||||||
|
name=baseos repository
|
||||||
|
baseurl=https://edgecache.query.consul/almalinux/9.4/BaseOS/x86_64/os
|
||||||
|
gpgkey=http://edgecache.query.consul/almalinux/RPM-GPG-KEY-AlmaLinux-9
|
||||||
4
release/9/files/crb.repo
Normal file
4
release/9/files/crb.repo
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[crb]
|
||||||
|
name=crb repository
|
||||||
|
baseurl=https://edgecache.query.consul/almalinux/9.4/CRB/x86_64/os
|
||||||
|
gpgkey=http://edgecache.query.consul/almalinux/RPM-GPG-KEY-AlmaLinux-9
|
||||||
4
release/9/files/epel.repo
Normal file
4
release/9/files/epel.repo
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[epel]
|
||||||
|
name=epel repository
|
||||||
|
baseurl=https://edgecache.query.consul/epel/9/Everything/x86_64
|
||||||
|
gpgkey=http://edgecache.query.consul/epel/RPM-GPG-KEY-EPEL-9
|
||||||
4
release/9/files/extras.repo
Normal file
4
release/9/files/extras.repo
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[extras]
|
||||||
|
name=extras repository
|
||||||
|
baseurl=https://edgecache.query.consul/almalinux/9.4/extras/x86_64/os
|
||||||
|
gpgkey=http://edgecache.query.consul/almalinux/RPM-GPG-KEY-AlmaLinux-9
|
||||||
4
release/9/files/highavailability.repo
Normal file
4
release/9/files/highavailability.repo
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[highavailability]
|
||||||
|
name=highavailability repository
|
||||||
|
baseurl=https://edgecache.query.consul/almalinux/9.4/HighAvailability/x86_64/os
|
||||||
|
gpgkey=http://edgecache.query.consul/almalinux/RPM-GPG-KEY-AlmaLinux-9
|
||||||
10
release/9/files/unkin.repo
Normal file
10
release/9/files/unkin.repo
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
[unkin]
|
||||||
|
name=unkin repository
|
||||||
|
baseurl=https://git.query.consul/api/packages/unkin/rpm/almalinux/el8
|
||||||
|
gpgcheck=False
|
||||||
|
gpgkey=https://git.query.consul/api/packages/unkin/rpm/repository.key
|
||||||
|
[unkinben]
|
||||||
|
name=unkinben repository
|
||||||
|
baseurl=https://git.query.consul/api/packages/unkinben/rpm/el9
|
||||||
|
gpgcheck=False
|
||||||
|
gpgkey=https://git.query.consul/api/packages/unkinben/rpm/repository.key
|
||||||
Reference in New Issue
Block a user