A Docker image providing PHP-FPM. Compared to other PHP images, this one is tailored to run without root privileges. All processes use an unprivileged user (uid 1000). And much work has been put into providing proper console output and meaningful messages.
$ docker run flownative/php
Here's an example of a Docker Compose configuration using this image as a PHP-FPM container. The configuration should give you an idea of how to integrate the image, but you'll certainly need to provide more code in order to get it running with your specific application.
For a full-working solution tailored to Neos CMS and Neos Flow, please have a look at Local Beach instead.
volumes:
application:
name: app
driver: local
services:
webserver:
image: flownative/nginx:4
ports:
- "8080"
volumes:
- application:/application
environment:
- NGINX_PHP_FPM_HOST=app_php.local_beach
php:
image: flownative/php:8.3
volumes:
- application:/application
environment:
By default, the PHP logs are written to STDOUT / STDERR. That way, you
can follow logs by watching container logs with docker logs
or using a
similar mechanism in Kubernetes or your actual platform.
Variable Name | Type | Default | Description |
---|---|---|---|
PHP_BASE_PATH | string | /opt/flownative/php | Base path for PHP (read-only) |
PHP_DATE_TIMEZONE | string | UTC | Default timezone (doc) |
PHP_ERROR_REPORTING | string | 2147483647 | PHP error reporting log levels (doc) |
PHP_DISPLAY_ERRORS | string | off | Display PHP errors (doc) |
PHP_ERROR_LOG | string | /dev/stderr | Path leading to the file where PHP errors should be logged |
PHP_FPM_ERROR_LOG_PATH | string | /opt/flownative/log/php-fpm-error.log | Path leading to the file where PHP-FPM errors should be logged |
PHP_FPM_ACCESS_LOG_PATH | string | /opt/flownative/log/php-fpm-access.log | Path leading to the file where PHP-FPM access should be logged |
PHP_MEMORY_LIMIT | string | 750M | PHP memory limit (doc) |
PHP_OPCACHE_PRELOAD | string | Path and filename of a preload script (doc) | |
PHP_XDEBUG_ENABLE | boolean | false | Enable or disable the Xdebug extension |
PHP_XDEBUG_MODE | string | develop | Controls which Xdebug features are enabled, for example "develop" or "debug". See Xdebug manual for details |
PHP_XDEBUG_CONFIG | string | Values assigned to this variable are propagated as XDEBUG_CONFIG. See Xdebug manual for details | |
PHP_XDEBUG_DISCOVER_CLIENT_HOST | boolean | false | If enabled, Xdebug will first try to connect to the client that made the HTTP request. See Xdebug manual for details |
PHP_XDEBUG_CLIENT_HOST | string | Configures the IP address or hostname where Xdebug will attempt to connect to when initiating a debugging connection. See Xdebug manual for details | |
PHP_XDEBUG_MAX_NESTING_LEVEL | integer | 512 | Controls the protection mechanism for infinite recursion protection. See Xdebug manual for details |
PHP_IGBINARY_ENABLE | boolean | false | Enable or disable the igbinary extension |
PHP_EXCIMER_ENABLE | boolean | false | Enable or disable the Excimer extension |
PHP_FPM_USER | string | 1000 | User id for running PHP (read-only) |
PHP_FPM_GROUP | string | 1000 | Group id for running PHP (read-only) |
PHP_FPM_PORT | string | 9000 | Port the PHP-FPM process listens to |
PHP_FPM_MAX_CHILDREN | string | 20 | Maximum number of children to run |
PHP_FPM_PM_MODE | string | ondemand | Process manager mode for PHP-FPM; "static", "ondemand" or "dynamic" |
This image is designed to run as a non-root container. Using an
unprivileged user generally improves the security of an image, but may
have a few side-effects, especially when you try to debug something by
logging in to the container using docker exec
.
When you are running this image with Docker or in a Kubernetes context, you can take advantage of the non-root approach by disallowing privilege escalation:
$ docker run flownative/php:8.3 --security-opt=no-new-privileges
When you exec into this container running bash, you will notice your prompt claiming "I have no name!". That's nothing to worry about: The container runs as a user with uid 1000, but in fact that user does not even exist.
$ docker run -ti --name php --rm flownative/php:8.2 bash
I have no name!@5a0adf17e426:/$ whoami
whoami: cannot find name for user ID 1000
Build this image with docker build
. You need to specify the desired
version for some of the tools as build arguments:
docker build \
--build-arg PHP_VERSION=8.3.11 \
-t flownative/php:latest .
Check the latest stable release on php.net.
The Flownative images are built through Github Workflows. A new release build is triggered whenever a new Git tag is pushed to this repository. As usual, the tag must follow the syntax "v1.2.3+4". Note that the tag is used for the code of this repository and has nothing to do with an actual PHP version.
In order to produce images for a new PHP version, update the
PHP_VERSION
constants found in .github/workflows/docker.build.yaml
,
commit the result and push it along with a new tag. Note that, because
you did not fix a bug or add a feature of the actual image code, you
should only raise the build version number (ie. v1.2.0+1 becomes
v1.2.0+2). The Github workflow will build images for all supported PHP
branches, tag them and push them to the container registries at Github,
Google and Docker Hub.
Each night, the images for the most recent version of each branch will
be rebuilt using the latest Flownative base image (flownative/base
).
Whenever new images were built, a custom event is triggered which in
turn triggers builds of the flownative/beach-php
image, which is
derived from this one.