Skip to content

Commit

Permalink
Merge pull request #55 from theohbrothers/enhancement/add-php-8.3.1-v…
Browse files Browse the repository at this point in the history
…ariants

Enhancement: Add php 8.3.1 variants
  • Loading branch information
theohbrothersbot authored Jan 3, 2024
2 parents 6bc1eef + 8e0cb87 commit d4ee44e
Show file tree
Hide file tree
Showing 6 changed files with 400 additions and 2 deletions.
258 changes: 257 additions & 1 deletion .github/workflows/ci-master-pr.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,260 @@ jobs:
run: |
git diff --exit-code
build-8-3-1:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3

- name: Display system info (linux)
run: |
set -e
hostname
whoami
cat /etc/*release
lscpu
free
df -h
pwd
docker info
docker version
# See: https://github.com/docker/build-push-action/blob/v2.6.1/docs/advanced/cache.md#github-cache
- name: Set up QEMU
uses: docker/setup-qemu-action@v2

- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@v2

- name: Cache Docker layers
uses: actions/cache@v3
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-8.3.1-${{ github.sha }}
restore-keys: |
${{ runner.os }}-buildx-8.3.1-
${{ runner.os }}-buildx-
- name: Login to Docker Hub registry
# Run on master and tags
if: github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/')
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_REGISTRY_USER }}
password: ${{ secrets.DOCKERHUB_REGISTRY_PASSWORD }}

# This step generates the docker tags
- name: Prepare
id: prep-8-3-1-fpm-alpine
run: |
set -e
# Get ref, i.e. <branch_name> from refs/heads/<branch_name>, or <tag-name> from refs/tags/<tag_name>. E.g. 'master' or 'v0.0.0'
REF=$( echo "${GITHUB_REF}" | rev | cut -d '/' -f 1 | rev )
# Get short commit hash E.g. 'abc0123'
SHA=$( echo "${GITHUB_SHA}" | cut -c1-7 )
# Generate docker image tags
# E.g. 'v0.0.0-<variant>' and 'v0.0.0-abc0123-<variant>'
# E.g. 'master-<variant>' and 'master-abc0123-<variant>'
VARIANT="8.3.1-fpm-alpine"
REF_VARIANT="${REF}-${VARIANT}"
REF_SHA_VARIANT="${REF}-${SHA}-${VARIANT}"
# Pass variables to next step
echo "VARIANT_BUILD_DIR=$VARIANT_BUILD_DIR" >> $GITHUB_OUTPUT
echo "VARIANT=$VARIANT" >> $GITHUB_OUTPUT
echo "REF_VARIANT=$REF_VARIANT" >> $GITHUB_OUTPUT
echo "REF_SHA_VARIANT=$REF_SHA_VARIANT" >> $GITHUB_OUTPUT
- name: 8.3.1-fpm-alpine - Build (PRs)
# Run only on pull requests
if: github.event_name == 'pull_request'
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine
platforms:
push: false
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

- name: 8.3.1-fpm-alpine - Build and push (master)
# Run only on master
if: github.ref == 'refs/heads/master'
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

- name: 8.3.1-fpm-alpine - Build and push (release)
if: startsWith(github.ref, 'refs/tags/')
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:latest
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

# This step generates the docker tags
- name: Prepare
id: prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
run: |
set -e
# Get ref, i.e. <branch_name> from refs/heads/<branch_name>, or <tag-name> from refs/tags/<tag_name>. E.g. 'master' or 'v0.0.0'
REF=$( echo "${GITHUB_REF}" | rev | cut -d '/' -f 1 | rev )
# Get short commit hash E.g. 'abc0123'
SHA=$( echo "${GITHUB_SHA}" | cut -c1-7 )
# Generate docker image tags
# E.g. 'v0.0.0-<variant>' and 'v0.0.0-abc0123-<variant>'
# E.g. 'master-<variant>' and 'master-abc0123-<variant>'
VARIANT="8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets"
REF_VARIANT="${REF}-${VARIANT}"
REF_SHA_VARIANT="${REF}-${SHA}-${VARIANT}"
# Pass variables to next step
echo "VARIANT_BUILD_DIR=$VARIANT_BUILD_DIR" >> $GITHUB_OUTPUT
echo "VARIANT=$VARIANT" >> $GITHUB_OUTPUT
echo "REF_VARIANT=$REF_VARIANT" >> $GITHUB_OUTPUT
echo "REF_SHA_VARIANT=$REF_SHA_VARIANT" >> $GITHUB_OUTPUT
- name: 8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets - Build (PRs)
# Run only on pull requests
if: github.event_name == 'pull_request'
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
platforms:
push: false
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

- name: 8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets - Build and push (master)
# Run only on master
if: github.ref == 'refs/heads/master'
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

- name: 8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets - Build and push (release)
if: startsWith(github.ref, 'refs/tags/')
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

# This step generates the docker tags
- name: Prepare
id: prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
run: |
set -e
# Get ref, i.e. <branch_name> from refs/heads/<branch_name>, or <tag-name> from refs/tags/<tag_name>. E.g. 'master' or 'v0.0.0'
REF=$( echo "${GITHUB_REF}" | rev | cut -d '/' -f 1 | rev )
# Get short commit hash E.g. 'abc0123'
SHA=$( echo "${GITHUB_SHA}" | cut -c1-7 )
# Generate docker image tags
# E.g. 'v0.0.0-<variant>' and 'v0.0.0-abc0123-<variant>'
# E.g. 'master-<variant>' and 'master-abc0123-<variant>'
VARIANT="8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug"
REF_VARIANT="${REF}-${VARIANT}"
REF_SHA_VARIANT="${REF}-${SHA}-${VARIANT}"
# Pass variables to next step
echo "VARIANT_BUILD_DIR=$VARIANT_BUILD_DIR" >> $GITHUB_OUTPUT
echo "VARIANT=$VARIANT" >> $GITHUB_OUTPUT
echo "REF_VARIANT=$REF_VARIANT" >> $GITHUB_OUTPUT
echo "REF_SHA_VARIANT=$REF_SHA_VARIANT" >> $GITHUB_OUTPUT
- name: 8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug - Build (PRs)
# Run only on pull requests
if: github.event_name == 'pull_request'
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
platforms:
push: false
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

- name: 8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug - Build and push (master)
# Run only on master
if: github.ref == 'refs/heads/master'
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

- name: 8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug - Build and push (release)
if: startsWith(github.ref, 'refs/tags/')
uses: docker/build-push-action@v3
with:
context: variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-3-1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_SHA_VARIANT }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

# Temp fix
# https://github.com/docker/build-push-action/issues/252
# https://github.com/moby/buildkit/issues/1896
- name: Move cache
run: |
rm -rf /tmp/.buildx-cache
mv /tmp/.buildx-cache-new /tmp/.buildx-cache
build-8-2-14:
runs-on: ubuntu-latest
steps:
Expand Down Expand Up @@ -141,7 +395,6 @@ jobs:
${{ github.repository }}:${{ steps.prep-8-2-14-fpm-alpine.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-14-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-14-fpm-alpine.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:latest
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

Expand Down Expand Up @@ -1554,6 +1807,7 @@ jobs:
update-draft-release:
needs:
- build-8-3-1
- build-8-2-14
- build-8-1-27
- build-8-0-30
Expand All @@ -1573,6 +1827,7 @@ jobs:

publish-draft-release:
needs:
- build-8-3-1
- build-8-2-14
- build-8-1-27
- build-8-0-30
Expand All @@ -1594,6 +1849,7 @@ jobs:

update-dockerhub-description:
needs:
- build-8-3-1
- build-8-2-14
- build-8-1-27
- build-8-0-30
Expand Down
5 changes: 4 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,10 @@ Dockerized php with php extension(s), based on [official php images](https://hub

| Tag | Dockerfile Build Context |
|:-------:|:---------:|
| `:8.2.14-fpm-alpine`, `:latest` | [View](variants/8.2.14-fpm-alpine) |
| `:8.3.1-fpm-alpine`, `:latest` | [View](variants/8.3.1-fpm-alpine) |
| `:8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets` | [View](variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets) |
| `:8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug` | [View](variants/8.3.1-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug) |
| `:8.2.14-fpm-alpine` | [View](variants/8.2.14-fpm-alpine) |
| `:8.2.14-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets` | [View](variants/8.2.14-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets) |
| `:8.2.14-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug` | [View](variants/8.2.14-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug) |
| `:8.1.27-fpm-alpine` | [View](variants/8.1.27-fpm-alpine) |
Expand Down
1 change: 1 addition & 0 deletions generate/definitions/versions.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
{
"php": {
"versions": [
"8.3.1",
"8.2.14",
"8.1.27",
"8.0.30",
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
FROM php:8.3.1-fpm-alpine

# opcache
RUN set -eux; \
docker-php-ext-install opcache

# mysqli (deprecated)
RUN set -eux; \
docker-php-ext-install mysqli

# gd
RUN set -eux; \
apk add --no-cache freetype libjpeg-turbo libpng; \
apk add --no-cache --virtual .deps freetype-dev libjpeg-turbo-dev libpng-dev; \
docker-php-ext-configure gd \
--with-freetype=/usr/include/ \
--with-jpeg=/usr/include/; \
docker-php-ext-install gd; \
docker-php-source delete; \
apk del .deps

# PDO: mysql driver
RUN set -eux; \
docker-php-ext-install pdo pdo_mysql

# PDO: pgsql driver
# See: https://github.com/docker-library/php/issues/221
RUN set -eux; \
apk add --no-cache postgresql-libs; \
apk add --no-cache --virtual .deps postgresql-dev; \
docker-php-ext-install pdo_pgsql; \
apk del .deps

# memcached
# See: https://stackoverflow.com/questions/40894385/how-can-i-install-the-php-memcached-extension-on-dockers-php7-alpine-image
RUN set -eux; \
apk add --no-cache libmemcached-libs zlib; \
apk add --no-cache --virtual .phpize-deps $PHPIZE_DEPS; \
apk add --no-cache --virtual .deps zlib-dev libmemcached-dev cyrus-sasl-dev; \
pecl install memcached; \
echo "extension=memcached.so" > /usr/local/etc/php/conf.d/20_memcached.ini; \
docker-php-source delete; \
apk del .deps; \
apk del .phpize-deps;

# Sockets
# See: https://github.com/docker-library/php/issues/181#issuecomment-173365852
RUN set -eux; \
apk add --no-cache --virtual .deps linux-headers; \
docker-php-ext-install sockets; \
apk del .deps

# Xdebug: https://stackoverflow.com/questions/46825502/how-do-i-install-xdebug-on-dockers-official-php-fpm-alpine-image
# PHPIZE_DEPS: autoconf dpkg-dev dpkg file g++ gcc libc-dev make pkgconf re2c
RUN set -eux; \
apk add --no-cache --virtual .build-dependencies $PHPIZE_DEPS; \
apk add --no-cache --virtual .deps linux-headers; \
pecl install xdebug-3.3.1; \
docker-php-ext-enable xdebug; \
docker-php-source delete; \
apk del .deps; \
apk del .build-dependencies
RUN set -eux; \
{ \
echo "[xdebug]"; \
echo "zend_extension=xdebug"; \
echo "xdebug.mode=debug"; \
echo "xdebug.start_with_request=yes"; \
echo "xdebug.client_host=host.docker.internal"; \
echo "xdebug.client_port=9000"; \
} > /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini;

RUN set -eux; \
echo; \
php -i; \
php -m
Loading

0 comments on commit d4ee44e

Please sign in to comment.