Compare commits

...

8 Commits

Author SHA1 Message Date
unkinben 40354e381f Merge pull request 'feat: change unkin repo to el9' (#8) from neoloc/unkin-el9 into master
Deploy / build (push) Successful in 59s
Reviewed-on: https://git.query.consul/unkin/docker-almalinux-base/pulls/8
2024-12-20 21:15:14 +11:00
unkinben 68fe3847d7 feat: change unkin repo to el9
Build / build (pull_request) Successful in 1m33s
2024-12-20 20:51:48 +11:00
unkinben ded1f70b31 Merge pull request 'feat: enable building multiple almalinux releases' (#7) from neoloc/multirelease into master
Deploy / build (push) Successful in 1m9s
Reviewed-on: https://git.query.consul/unkin/docker-almalinux-base/pulls/7
2024-12-20 19:52:12 +11:00
unkinben 9491ad8c61 feat: enable building multiple almalinux releases
Build / build (pull_request) Successful in 1m36s
- create releases/{version} directories
- move almalinux8 to releases/8
- create almalinx9 build
- update makefile to work with multiple versions
2024-12-20 19:39:40 +11:00
unkinben bf0efbc306 Merge pull request 'feat: update unkin repos' (#6) from neoloc/repos into master
Deploy / build (push) Successful in 2m2s
Reviewed-on: https://git.query.consul/unkin/docker-almalinux-base/pulls/6
2024-12-01 00:52:47 +11:00
unkinben 4ee7d787f9 feat: update unkin repos
Build / build (pull_request) Successful in 1m42s
2024-12-01 00:50:22 +11:00
unkinben c8c94f7771 Merge pull request 'feat: migrate to gitea actions' (#5) from neoloc/actions into master
Deploy / build (push) Successful in 2m9s
Reviewed-on: https://git.query.consul/unkin/docker-almalinux-base/pulls/5
2024-09-08 02:05:12 +10:00
unkinben 4926c57c30 feat: migrate to gitea actions
Build / build (pull_request) Successful in 1m23s
- change from droneci to gitea actions
- update Dockerfile cleanup stage
2024-09-08 02:02:51 +10:00
20 changed files with 182 additions and 84 deletions
-53
View File
@@ -1,53 +0,0 @@
kind: pipeline
type: docker
name: build-docker-image
steps:
- name: build
image: docker:dind
volumes:
- name: dockersock
path: /var/run/docker.sock
commands:
- apk add --no-cache make bash git
- make build
- name: push
image: docker:dind
environment:
DOCKER_USERNAME:
from_secret: docker_username
DOCKER_PASSWORD:
from_secret: docker_password
volumes:
- name: dockersock
path: /var/run/docker.sock
when:
branch:
- master
event:
- push
commands:
- apk add --no-cache make bash git
- echo "$DOCKER_PASSWORD" | docker login --username=$DOCKER_USERNAME --password-stdin git.query.consul
- make push
- name: clean
image: docker:dind
volumes:
- name: dockersock
path: /var/run/docker.sock
commands:
- apk add --no-cache make bash git
- make clean
volumes:
- name: dockersock
host:
path: /var/run/docker.sock
trigger:
event:
- push
- pull_request
+26
View File
@@ -0,0 +1,26 @@
name: Build
on:
pull_request:
jobs:
build:
runs-on: almalinux-8
container:
image: git.query.consul/unkin/almalinux8:latest
options: --privileged
steps:
- name: Set up environment
run: |
dnf install -y yum-utils
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
dnf module enable -y nodejs:20
dnf install -y docker-ce-cli make bash git nodejs
- name: Checkout code
uses: actions/checkout@v3
- name: Build Docker Image
run: |
make build
+39
View File
@@ -0,0 +1,39 @@
name: Deploy
on:
push:
branches:
- master
jobs:
build:
runs-on: almalinux-8
container:
image: git.query.consul/unkin/almalinux8:latest
options: --privileged
steps:
- name: Set up environment
run: |
dnf install -y yum-utils
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
dnf module enable -y nodejs:20
dnf install -y docker-ce-cli make bash git nodejs
- name: Checkout code
uses: actions/checkout@v3
- name: Build Docker Image
run: |
make build
- name: Log in to Docker
env:
UPLOAD_USER: ${{ secrets.UPLOAD_USER }}
UPLOAD_PASS: ${{ secrets.UPLOAD_PASS }}
run: |
echo "$UPLOAD_PASS" | docker login --username=$UPLOAD_USER --password-stdin git.query.consul
- name: Push Docker Image
run: |
make push
+38 -22
View File
@@ -1,33 +1,49 @@
# Get the current Git commit hash
# Variables
GIT_COMMIT := $(shell git rev-parse --short HEAD)
# Get the current date in YYYYMMDD format
DATE_TAG := $(shell date +%Y%m%d)
# Set the Docker image name and repository information
IMAGE_NAME := almalinux8
IMAGE_NAME := almalinux
REGISTRY := git.query.consul
OWNER := unkin
# Build the Docker image (without tags)
build:
docker build --network=host -t $(REGISTRY)/$(OWNER)/$(IMAGE_NAME) .
# List of releases (directories under ./release)
RELEASES := $(shell find release -mindepth 1 -maxdepth 1 -type d -exec basename {} \;)
# Tag the Docker image with the Git commit hash, the date, and 'latest'
tag:
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
# Default target (build all images)
default: build-all
# Push the Docker image to a repository with all tags
push: tag
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):$(GIT_COMMIT)
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):$(DATE_TAG)
docker push $(REGISTRY)/$(OWNER)/$(IMAGE_NAME):latest
# List all available releases
list:
@echo "Available releases:"
@echo $(RELEASES) | tr ' ' '\n'
# 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:
docker image prune -f
# Default target
default: build
# Build a specific release
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
+1 -1
View File
@@ -2,5 +2,5 @@
[![Build Status](https://droneci.query.consul/api/badges/unkin/docker-almalinux-base/status.svg)](https://droneci.query.consul/unkin/docker-almalinux-base)
This project provides a reproducible Docker image build process for `almalinux:8.10`, with custom YUM repository configurations and package installations. The build is automated using a `Makefile` and managed via Drone CI to ensure consistent and reliable Docker image builds.
This project provides a reproducible Docker image build process for `almalinux:8.10`, with custom YUM repository configurations and package installations. The build is automated using a `Makefile` and managed via CI tasks to ensure consistent and reliable Docker image builds.
-6
View File
@@ -1,6 +0,0 @@
[gitea-unkin-almalimnux-8]
name=unkin - Gitea - almalimnux - 8
baseurl=https://git.query.consul/api/packages/unkin/rpm/almalimnux/8
enabled=1
gpgcheck=1
gpgkey=https://git.query.consul/api/packages/unkin/rpm/repository.key
+4 -2
View File
@@ -17,6 +17,8 @@ RUN dnf clean all && \
# Update the system and install required packages
RUN dnf update -y && \
dnf install -y curl git && \
dnf clean all && \
dnf install -y curl git
# Cleanup
RUN dnf clean all && \
rm -rf /var/cache/dnf
+16
View File
@@ -0,0 +1,16 @@
[unkin]
name=unkin repository
baseurl=https://git.query.consul/api/packages/unkin/rpm/almalinux/el8
gpgkey=https://git.query.consul/api/packages/unkin/rpm/repository.key
gpgcheck=False
[unkinben]
name=unkinben repository
baseurl=https://git.query.consul/api/packages/unkinben/rpm/el8
gpgcheck=False
gpgkey=https://git.query.consul/api/packages/unkinben/rpm/repository.key
[gitea-unkin-almalimnux-8]
name=unkin - Gitea - almalimnux - 8
baseurl=https://git.query.consul/api/packages/unkin/rpm/almalimnux/8
enabled=1
gpgcheck=1
gpgkey=https://git.query.consul/api/packages/unkin/rpm/repository.key
+24
View 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
View 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
View 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
View 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
View 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
View 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
View 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
View File
@@ -0,0 +1,10 @@
[unkin]
name=unkin repository
baseurl=https://git.query.consul/api/packages/unkin/rpm/almalinux/el9
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