Skip to content

GitLab (CE/EE) Docker Image for ARM64 - Up-to-Date Images through automated GitHub-Actions

License

Notifications You must be signed in to change notification settings

feskol/gitlab-arm64

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

27 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

GitLab (CE/EE) Docker Image for ARM64

build-github-action syncversion-github-action
Docker Image Docker Pulls gitlab-ce-latest-arm gitlab-ee-latest-arm gitlab-ce-latest-arm-size gitlab-ee-latest-arm-size
Supported GitLab Versions
Buy Me A Coffee PayPal

πŸš€ Overview

This repository provides GitLab Docker images for ARM64 architecture.

GitLab does not officially support ARM64 yet. As a result, GitLab does not provide Docker images for ARM64. While there are some repositories that attempt to address this issue, they often take time to release updates. This poses a challenge, especially when a security patch requires an immediate update.

To solve this problem, I created this repository providing a GitHub Action that checks for new releases daily and automatically builds a Docker image for the latest releases.

✨ Features

  • Automated Updates:
    A GitHub Action checks the latest releases of the official GitLab Docker images and triggers the build process when a new version is available.
    This ensures the repository always provides up-to-date images for ARM64.

  • Fully Automatic:
    No manual intervention is required. The entire process, from release checking to image building is automated.

  • Compatibility:
    These images are build for ARM64 architecture, making GitLab accessible to users on ARM-based platforms.
    They are also compatible with AMD64 architecture. For more details, see Multi-Architecture Support

πŸ“‹ Requirements

To use the Docker images built by this repository, you need:

  • ARM64 Architecture (e.g. Raspberry Pi 4/5, ARM64 servers) or AMD64 Architecture (See Multi-Architecture Support)
  • Docker installed on your system

πŸ› οΈ Usage

Pull the Docker images from Docker Hub.

# latest GitLab Community Edition (CE)
docker pull feskol/gitlab:latest
docker pull feskol/gitlab:ce     # "ce" is same as "latest"

# latest GitLab Enterprise Edition (EE)
docker pull feskol/gitlab:ee

# Specific version - replace "-ce" to "-ee" for Enterprise Edition
docker pull feskol/gitlab:17-ce
docker pull feskol/gitlab:17.7-ce
docker pull feskol/gitlab:17.7.0-ce
docker pull feskol/gitlab:17.7.0-ce.0

These images are used like GitLab’s official Docker images.
Refer to GitLab's Docker documentation for setup instructions:

Here’s an example setup using docker-compose.yaml:

services:
    gitlab:
        image: feskol/gitlab:17.7.0-ce # change the tag to your needs
        container_name: gitlab
        restart: unless-stopped
        hostname: 'gitlab.example.com'
        environment:
            GITLAB_OMNIBUS_CONFIG: |
                # Add any other gitlab.rb configuration here, each on its own line
                # For example: Reduce the number of running workers in order to reduce memory usage
                puma['worker_processes'] = 2
                sidekiq['concurrency'] = 9
        ports:
            - '80:80'
            - '443:443'
            - '22:22'
        volumes:
            - './config:/etc/gitlab'
            - './logs:/var/log/gitlab'
            - './data:/var/opt/gitlab'
        shm_size: '256m'

🐳 Multi-Architecture Support

gitlab-ce-latest-amd gitlab-ee-latest-amd gitlab-ce-latest-amd-size gitlab-ee-latest-amd-size

This repository supports multi-architecture Docker images in addition to ARM64 images. This enhancement ensures that the Docker images can run seamlessly on both AMD64 and ARM64 architectures.

Supported Architectures

  • ARM64: Optimized for ARM64 systems.
  • AMD64: Uses the official GitLab Docker image.

Benefits

  • Cross-Platform Compatibility: Use the same image across multiple platforms.
  • Streamlined Workflows: Unified image tagging for multi-arch builds simplifies deployment.

How It Works

The build process creates a docker manifest for multi-arch images. For AMD64, the process leverages the official GitLab Docker image to ensure compatibility and reliability.

Usage

To pull the appropriate image for your architecture, simply use:

docker pull feskol/gitlab:latest    # you can use here any tag from the DockerHub (e.g. 17.6.2-ce / 17.6-ce / ce )

Docker will automatically fetch the image matching your system architecture.

🏷️ Tags

The following tags are available for the Docker images, providing flexibility and alignment with GitLab's versioning system:

  • latest:
    Points to the newest Community Edition (CE) release available.

  • ce:
    Represents the newest Community Edition (CE) release available.

  • ee:
    Represents the newest Enterprise Edition (EE) release available.

  • Version-specific tags:
    Tags are generated based on GitLab's versioning system: (major).(minor).(patch)-(edition).0.
    For example, if the newest version is 17.6.1-ce.0, the following Docker image tags are created pointing to that version:

    • 17.6.1-ce.0 (original GitLab version)
    • 17.6.1-ce (version without the .0 suffix)
    • 17.6-ce (major and minor version)
    • 17-ce (major version only)

Find all available tags on Docker Hub.

Note

This project supports GitLab (CE/EE) starting from version 17 and higher!

πŸ”„ Update

Using Docker Compose

  1. Stop the container:
docker compose down
  1. Update the docker-compose.yaml file to the new version tag.
# Old image tag:
services:
    gitlab:
        image: feskol/gitlab:17.5.4-ce # outdated version
...

# New image tag
services:
    gitlab:
        image: feskol/gitlab:17.6.2-ce # updated version
...
  1. Restart the container:
docker compose up -d

Warning

Always follow the official update guide.
Use GitLab's Upgrade Path Tool for step-by-step guidance on update paths.

🌐 Links

Here are the links used by this repository:

🀝 Contribution Guidelines

We welcome contributions to this project! To ensure clarity and fairness for all contributors, we require that all contributors sign our Contributor License Agreement (CLA).

By signing the CLA, you confirm that:

  1. You grant us the perpetual, worldwide, non-exclusive, royalty-free, irrevocable right to use, modify, sublicense, and distribute your contribution as part of this project or any other project.
  2. You retain ownership of your contribution, but grant us the rights necessary to use it without restriction.
  3. Your contribution does not violate the rights of any third party.

How to Sign the CLA

Before submitting a pull request, please sign the CLA using the following link:
Sign the CLA

Contributions cannot be merged unless the CLA is signed.

Thank you for your contributions and for helping us build something great!

πŸ§ͺ Testing

Tests can be found in the ./tests/unit.
To ensure everyone uses the same test suite, I provided a Dockerfile with a docker-compose.yaml file that runs the tests.

We're using bashunit for testing our scripts. Its binary is located in the ./lib directory.
To ensure dependencies remain up-to-date, a GitHub Action (.github/workflows/bashunit-update.yml) has been set up to check for new releases on a weekly basis. If a new release is found, a pull request (PR) is automatically created. Since there are existing GitHub Actions that run tests using bashunit, it tries to automatically merge the PR if no errors occur.

Command:

To run the tests, run:

# Run all tests
docker compose run --rm test

# Run tests for specific folder
docker compose run --rm test ../lib/bashunit ./unit/workflows/build

If you encounter errors, try using the --verbose option for more details.

docker compose run --rm test ../lib/bashunit --verbose ./unit

Structure:

...
β”œβ”€β”€ lib                 # bashunit binary
β”œβ”€β”€ scripts             # scripts for the build/syncversion workflows
└── tests
    β”œβ”€β”€ fixtures        # fixtures for the tests
    β”œβ”€β”€ helper          # helping scripts (e.g. "test-case.sh"-files)
    └── unit            # The actual tests

❀️ Support This Project

If you find this project helpful and would like to support my work:

  • 🌟 Star the repository to show your appreciation.
  • πŸ’Έ Donate via:
    • Buy Me a Coffe: Buy Me A Coffee
    • PayPal: PayPal

Thank you for your support!