Skip to content

Commit

Permalink
Merge pull request #61 from theohbrothers/enhancement/bump-php-8.2-va…
Browse files Browse the repository at this point in the history
…riants-to-8.2.16

Enhancement: Bump php 8.2 variants to 8.2.16
  • Loading branch information
theohbrothersbot authored Feb 17, 2024
2 parents e5ff99c + aa60dd3 commit 0a98f66
Show file tree
Hide file tree
Showing 6 changed files with 193 additions and 55 deletions.
102 changes: 51 additions & 51 deletions .github/workflows/ci-master-pr.yml
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,7 @@ jobs:
rm -rf /tmp/.buildx-cache
mv /tmp/.buildx-cache-new /tmp/.buildx-cache
build-8-2-15:
build-8-2-16:
runs-on: ubuntu-latest
steps:
- name: Checkout
Expand Down Expand Up @@ -318,9 +318,9 @@ jobs:
uses: actions/cache@v3
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-8.2.15-${{ github.sha }}
key: ${{ runner.os }}-buildx-8.2.16-${{ github.sha }}
restore-keys: |
${{ runner.os }}-buildx-8.2.15-
${{ runner.os }}-buildx-8.2.16-
${{ runner.os }}-buildx-
- name: Login to Docker Hub registry
Expand All @@ -333,7 +333,7 @@ jobs:

# This step generates the docker tags
- name: Prepare
id: prep-8-2-15-fpm-alpine
id: prep-8-2-16-fpm-alpine
run: |
set -e
Expand All @@ -346,7 +346,7 @@ jobs:
# 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.2.15-fpm-alpine"
VARIANT="8.2.16-fpm-alpine"
REF_VARIANT="${REF}-${VARIANT}"
REF_SHA_VARIANT="${REF}-${SHA}-${VARIANT}"
Expand All @@ -356,51 +356,51 @@ jobs:
echo "REF_VARIANT=$REF_VARIANT" >> $GITHUB_OUTPUT
echo "REF_SHA_VARIANT=$REF_SHA_VARIANT" >> $GITHUB_OUTPUT
- name: 8.2.15-fpm-alpine - Build (PRs)
- name: 8.2.16-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.2.15-fpm-alpine
context: variants/8.2.16-fpm-alpine
platforms:
push: false
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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.2.15-fpm-alpine - Build and push (master)
- name: 8.2.16-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.2.15-fpm-alpine
context: variants/8.2.16-fpm-alpine
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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.2.15-fpm-alpine - Build and push (release)
- name: 8.2.16-fpm-alpine - Build and push (release)
if: startsWith(github.ref, 'refs/tags/')
uses: docker/build-push-action@v3
with:
context: variants/8.2.15-fpm-alpine
context: variants/8.2.16-fpm-alpine
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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

# This step generates the docker tags
- name: Prepare
id: prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
id: prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
run: |
set -e
Expand All @@ -413,7 +413,7 @@ jobs:
# 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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets"
VARIANT="8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets"
REF_VARIANT="${REF}-${VARIANT}"
REF_SHA_VARIANT="${REF}-${SHA}-${VARIANT}"
Expand All @@ -423,51 +423,51 @@ jobs:
echo "REF_VARIANT=$REF_VARIANT" >> $GITHUB_OUTPUT
echo "REF_SHA_VARIANT=$REF_SHA_VARIANT" >> $GITHUB_OUTPUT
- name: 8.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets - Build (PRs)
- name: 8.2.16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
context: variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
platforms:
push: false
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets - Build and push (master)
- name: 8.2.16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
context: variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets - Build and push (release)
- name: 8.2.16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
context: variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
id: prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
run: |
set -e
Expand All @@ -480,7 +480,7 @@ jobs:
# 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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug"
VARIANT="8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug"
REF_VARIANT="${REF}-${VARIANT}"
REF_SHA_VARIANT="${REF}-${SHA}-${VARIANT}"
Expand All @@ -490,45 +490,45 @@ jobs:
echo "REF_VARIANT=$REF_VARIANT" >> $GITHUB_OUTPUT
echo "REF_SHA_VARIANT=$REF_SHA_VARIANT" >> $GITHUB_OUTPUT
- name: 8.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug - Build (PRs)
- name: 8.2.16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
context: variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
platforms:
push: false
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug - Build and push (master)
- name: 8.2.16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
context: variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug - Build and push (release)
- name: 8.2.16-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.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
context: variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug
platforms:
push: true
tags: |
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_SHA_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug.outputs.REF_VARIANT }}
${{ github.repository }}:${{ steps.prep-8-2-16-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

Expand Down Expand Up @@ -1808,7 +1808,7 @@ jobs:
update-draft-release:
needs:
- build-8-3-3
- build-8-2-15
- build-8-2-16
- build-8-1-27
- build-8-0-30
- build-7-4-33
Expand All @@ -1828,7 +1828,7 @@ jobs:
publish-draft-release:
needs:
- build-8-3-3
- build-8-2-15
- build-8-2-16
- build-8-1-27
- build-8-0-30
- build-7-4-33
Expand All @@ -1850,7 +1850,7 @@ jobs:
update-dockerhub-description:
needs:
- build-8-3-3
- build-8-2-15
- build-8-2-16
- build-8-1-27
- build-8-0-30
- build-7-4-33
Expand Down
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,9 @@ Dockerized php with php extension(s), based on [official php images](https://hub
| `:8.3.3-fpm-alpine`, `:latest` | [View](variants/8.3.3-fpm-alpine) |
| `:8.3.3-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets` | [View](variants/8.3.3-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets) |
| `:8.3.3-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug` | [View](variants/8.3.3-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug) |
| `:8.2.15-fpm-alpine` | [View](variants/8.2.15-fpm-alpine) |
| `:8.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets` | [View](variants/8.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets) |
| `:8.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug` | [View](variants/8.2.15-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug) |
| `:8.2.16-fpm-alpine` | [View](variants/8.2.16-fpm-alpine) |
| `:8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets` | [View](variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets) |
| `:8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug` | [View](variants/8.2.16-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug) |
| `:8.1.27-fpm-alpine` | [View](variants/8.1.27-fpm-alpine) |
| `:8.1.27-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets` | [View](variants/8.1.27-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets) |
| `:8.1.27-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug` | [View](variants/8.1.27-fpm-alpine-opcache-mysqli-gd-pdo-memcached-sockets-xdebug) |
Expand Down
2 changes: 1 addition & 1 deletion generate/definitions/versions.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"php": {
"versions": [
"8.3.3",
"8.2.15",
"8.2.16",
"8.1.27",
"8.0.30",
"7.4.33",
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
FROM php:8.2.16-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 0a98f66

Please sign in to comment.