Top Related Projects
GitHub action to set up PHP with extensions, php.ini configuration, coverage drivers, and various tools.
Full PHP development environment for Docker.
š³ Production-ready Docker images for PHP. Optimized for Laravel, WordPress, and more!
Quick Overview
The mlocati/docker-php-extension-installer is a GitHub repository that provides a script for easily installing PHP extensions in Docker containers. It simplifies the process of adding PHP extensions to Docker images, making it particularly useful for developers working with PHP in containerized environments.
Pros
- Simplifies the installation of PHP extensions in Docker containers
- Supports a wide range of PHP extensions
- Regularly updated to include new PHP versions and extensions
- Can be easily integrated into Dockerfiles
Cons
- Limited to PHP extensions only, not suitable for other language extensions
- May require additional configuration for some complex extensions
- Depends on external package repositories, which could potentially introduce security risks
- Performance impact when installing multiple extensions in a single Docker image
Getting Started
To use the docker-php-extension-installer in your Dockerfile, add the following lines:
ADD https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions /usr/local/bin/
RUN chmod +x /usr/local/bin/install-php-extensions && \
install-php-extensions gd xdebug redis
This example downloads the latest version of the script, makes it executable, and installs the GD, Xdebug, and Redis extensions. You can replace these with any supported PHP extensions you need for your project.
Competitor Comparisons
GitHub action to set up PHP with extensions, php.ini configuration, coverage drivers, and various tools.
Pros of setup-php
- Broader scope: Supports multiple operating systems (Ubuntu, macOS, Windows)
- GitHub Actions integration: Designed specifically for CI/CD workflows
- Extensive PHP tooling support: Includes Composer, PECL, and various PHP tools
Cons of setup-php
- Complexity: May be overkill for simple Docker-based PHP setups
- Learning curve: Requires understanding of GitHub Actions and workflow syntax
Code Comparison
setup-php (GitHub Actions workflow):
steps:
- uses: actions/checkout@v2
- uses: shivammathur/setup-php@v2
with:
php-version: '7.4'
extensions: mbstring, xml
coverage: xdebug
docker-php-extension-installer (Dockerfile):
FROM php:7.4-fpm
COPY --from=mlocati/php-extension-installer /usr/bin/install-php-extensions /usr/local/bin/
RUN install-php-extensions mbstring xml
Both projects aim to simplify PHP extension installation, but setup-php is more comprehensive and tailored for GitHub Actions, while docker-php-extension-installer is focused on Docker environments. setup-php offers broader platform support and additional PHP tooling, but may be more complex for simple use cases. docker-php-extension-installer provides a straightforward solution for Docker-based PHP projects with minimal overhead.
Full PHP development environment for Docker.
Pros of Laradock
- Comprehensive development environment with multiple services (PHP, MySQL, Redis, etc.)
- Pre-configured for Laravel projects, reducing setup time
- Active community and frequent updates
Cons of Laradock
- Larger footprint and potentially slower startup times
- May include unnecessary services for simpler projects
- Steeper learning curve for Docker beginners
Code Comparison
docker-php-extension-installer:
FROM php:7.4-fpm
ADD https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions /usr/local/bin/
RUN chmod +x /usr/local/bin/install-php-extensions && \
install-php-extensions gd xdebug
Laradock:
version: '3'
services:
php-fpm:
build:
context: ./php-fpm
args:
- INSTALL_XDEBUG=true
- INSTALL_GD=true
docker-php-extension-installer focuses solely on installing PHP extensions, making it lightweight and easy to use. It's ideal for projects that require specific PHP extensions without the need for a full development environment.
Laradock, on the other hand, provides a complete development environment with multiple services. It's better suited for complex projects, especially those using Laravel, but may be overkill for simpler applications.
š³ Production-ready Docker images for PHP. Optimized for Laravel, WordPress, and more!
Pros of docker-php
- Provides a more comprehensive PHP development environment with additional tools and configurations
- Offers pre-built images for various PHP versions and configurations
- Includes support for multiple web servers (Apache, Nginx) out of the box
Cons of docker-php
- May have a larger image size due to additional included tools and configurations
- Potentially more complex setup for users who only need basic PHP functionality
- Less focused on extension installation, which is the primary purpose of docker-php-extension-installer
Code Comparison
docker-php-extension-installer:
FROM php:7.4-fpm
ADD https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions /usr/local/bin/
RUN chmod +x /usr/local/bin/install-php-extensions && \
install-php-extensions gd xdebug
docker-php:
FROM serversideup/php:8.2-fpm-nginx
RUN apt-get update && apt-get install -y \
libpng-dev \
&& docker-php-ext-install gd
The docker-php-extension-installer focuses on simplifying extension installation, while docker-php provides a more complete development environment with pre-configured web servers and additional tools. Users should choose based on their specific needs and preferences for simplicity versus comprehensiveness.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Easy installation of PHP extensions in official PHP Docker images
This repository contains a script that can be used to easily install a PHP extension inside the official PHP Docker images.
The script will install all the required APT/APK packages; at the end of the script execution, the no-more needed packages will be removed so that the image will be much smaller.
Supported docker images are:
- Debian-based docker images: since jessie (Debian 8) (minimum PHP version: 5.5)
- Alpine-based docker images: since Alpine 3.9 (minimum PHP version: 7.1)
See also the notes in the Special requirements section.
Usage
You have many ways to use this script within your Dockerfile
s.
Here's a list of sample Dockerfile
s that install the GD and xdebug PHP extensions:
Downloading the script on the fly with ADD
FROM php:7.2-cli
ADD --chmod=0755 https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions /usr/local/bin/
RUN install-php-extensions gd xdebug
Downloading the script on the fly with curl
FROM php:7.2-cli
RUN curl -sSLf \
-o /usr/local/bin/install-php-extensions \
https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions && \
chmod +x /usr/local/bin/install-php-extensions && \
install-php-extensions gd xdebug
Direct execution with curl
FROM php:8.2-cli
RUN ( curl -sSLf https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions -o - || echo 'return 1' ) | sh -s \
gd xdebug
Copying the script from a Docker image
-
using GitHub Container Registry
FROM php:8.4-cli COPY --from=ghcr.io/mlocati/php-extension-installer /usr/bin/install-php-extensions /usr/local/bin/ RUN install-php-extensions gd xdebug
-
using Docker Hub
FROM php:8.4-cli COPY --from=mlocati/php-extension-installer /usr/bin/install-php-extensions /usr/local/bin/ RUN install-php-extensions gd xdebug
Warning: by using this method you may use an outdated version of the Docker image image.
You may want to run docker pull ghcr.io/mlocati/php-extension-installer
or docker pull mlocati/php-extension-installer
in order to use an up-to-date version.
Using the script of a Docker image
-
using GitHub Container Registry
RUN --mount=type=bind,from=ghcr.io/mlocati/php-extension-installer:latest,source=/usr/bin/install-php-extensions,target=/usr/local/bin/install-php-extensions \ install-php-extensions gd xdebug
-
using Docker Hub
RUN --mount=type=bind,from=mlocati/php-extension-installer:latest,source=/usr/bin/install-php-extensions,target=/usr/local/bin/install-php-extensions \ install-php-extensions gd xdebug
Warning: by using this method you may use an outdated version of the Docker image image.
You may want to run docker pull ghcr.io/mlocati/php-extension-installer
or docker pull mlocati/php-extension-installer
in order to use an up-to-date version.
Installing specific versions of an extension
Simply append -<version>
to the module name.
For example:
install-php-extensions xdebug-2.9.7
The script also supports resolving compatible versions by prefixing the version with a caret (^
).
For example:
# Install the most recent xdebug 2.x version (for example 2.9.8)
install-php-extensions xdebug-^2
# Install the most recent xdebug 2.8.x version (for example 2.8.1)
install-php-extensions xdebug-^2.8
Please remark that with the syntax above you'll get the vary latest compatible version, which may be unstable. In order to install the most recent stable version, you can append @stable
:
# Install the most recent STABLE xdebug 3.x version (for example 3.2.2)
install-php-extensions xdebug-^3@stable
(valid suffixes are: @snapshot
, @devel
, @alpha
, @beta
, and @stable
)
Pre-release versions extensions available on PECL
can be setup by suffixing the extension's name with its state i.e. alpha
, beta
, rc
, preview
, devel
or snapshot
.
For example:
install-php-extensions xdebug-beta
TIP: When the latest version available on PECL
is not stable, and you want to keep the last stable version,
force it by suffixing the extension's name with the stable
state.
For example:
install-php-extensions mongodb-stable
Installing an extension from its source code
You can also install PHP extensions from source code (provided that it comes with a package.xml
or a package2.xml
file).
Accepted formats are:
- A short version for repositories hosted on GitHub.
For example, for the php-memcached-dev/php-memcached GitHub repository, you can simply write:# Install from a specific commit (full commit SHA-1) install-php-extensions php-memcached-dev/php-memcached@8f106564e6bb005ca6100b12ccc89000daafa9d8 # Install from a specific commit (short commit SHA-1) install-php-extensions php-memcached-dev/php-memcached@8f106564e6bb # Install from tag v3.2.0RC2 install-php-extensions php-memcached-dev/php-memcached@v3.2.0RC2 install-php-extensions php-memcached-dev/php-memcached@refs/tags/v3.2.0RC2 # Install from branch master install-php-extensions php-memcached-dev/php-memcached@master install-php-extensions php-memcached-dev/php-memcached@refs/heads/master
- An URL providing an archive containing the source code.
Examples:# tgz archive for commit 8f106564e6bb005ca6100b12ccc89000daafa9d8 install-php-extensions https://codeload.github.com/php-memcached-dev/php-memcached/tar.gz/8f106564e6bb005ca6100b12ccc89000daafa9d8 # tgz archive for tag v3.1.5 install-php-extensions https://codeload.github.com/php-memcached-dev/php-memcached/tar.gz/refs/tags/v3.1.5 # tgz archive for branch master install-php-extensions https://codeload.github.com/php-memcached-dev/php-memcached/tar.gz/refs/heads/master
- The absolute path of a local directory.
Examples:# Download the source code curl -o /tmp/source.tgz https://codeload.github.com/php-memcached-dev/php-memcached/tar.gz/refs/tags/v3.1.5 tar xzf /tmp/source.tgz -C /tmp install-php-extensions /tmp/php-memcached-3.1.5
Installing composer
You can also install composer, and you also can specify a major version of it, or a full version.
Examples:
# Install the latest version
install-php-extensions @composer
# Install the latest 1.x version
install-php-extensions @composer-1
# Install a specific version
install-php-extensions @composer-2.0.2
Issue with Let's Encrypt certificates
The root CA certificate of Let's Encrypt changes (more details here).
That breaks old linux distributions, namely:
- Debian Jessie (8)
- Debian Stretch (9)
- Alpine Linux 3.7
- Alpine Linux 3.8
This script can fix this issue: simply pass @fix_letsencrypt
as an argument:
install-php-extensions @fix_letsencrypt
Supported PHP extensions
Extension | PHP 8.4 | PHP 8.3 | PHP 8.2 | PHP 8.1 | PHP 8.0 | PHP 7.4 | PHP 7.3 | PHP 7.2 | PHP 7.1 | PHP 7.0 | PHP 5.6 | PHP 5.5 |
---|---|---|---|---|---|---|---|---|---|---|---|---|
amqp | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
apcu | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
apcu_bc | ā | ā | ā | ā | ā | |||||||
ast | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
bcmath | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
bitset | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
blackfire | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
brotli | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
bz2 | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
calendar | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
cassandra* | ā | ā | ā | ā | ā | ā | ā | ā | ||||
cmark | ā | ā | ā | ā | ā | |||||||
csv | ā | ā | ā | ā | ā | ā | ā | |||||
dba | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
ddtrace* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
decimal | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
ds | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
ecma_intl* | ā | ā | ||||||||||
enchant | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
ev | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
event | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
excimer | ā | ā | ā | ā | ā | ā | ā | ā | ā | |||
exif | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
ffi | ā | ā | ā | ā | ā | ā | ||||||
ftp | ā | ā | ā | |||||||||
gd | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
gearman | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
geoip | ā | ā | ā | ā | ā | ā | ā | |||||
geos* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
geospatial | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
gettext | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
gmagick | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
gmp | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
gnupg | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
grpc | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
http | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
igbinary | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
imagick | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
imap | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
inotify | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
interbase | ā | ā | ā | ā | ā | ā | ||||||
intl | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
ion | ā | ā | ā | ā | ||||||||
ioncube_loader | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
jsmin | ā | ā | ā | ā | ā | ā | ā | |||||
json_post | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
jsonpath | ā | ā | ā | ā | ā | ā | ||||||
ldap | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
luasandbox | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
lz4* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
lzf | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
mailparse | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
maxminddb | ā | ā | ā | ā | ā | ā | ā | ā | ||||
mcrypt | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
md4c | ā | ā | ā | ā | ā | |||||||
memcache | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
memcached | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
memprof* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
mongo | ā | ā | ||||||||||
mongodb | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
mosquitto | ā | ā | ā | ā | ā | ā | ā | |||||
msgpack | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
mssql | ā | ā | ||||||||||
mysql | ā | ā | ||||||||||
mysqli | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
newrelic | ā | ā | ā | ā | ā | ā | ā | ā | ā | |||
oauth | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
oci8 | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
odbc | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
opcache | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
opencensus | ā | ā | ā | ā | ā | ā | ā | ā | ā | |||
openswoole | ā | ā | ā | ā | ā | ā | ā | |||||
opentelemetry | ā | ā | ā | ā | ā | |||||||
parallel* | ā | ā | ā | ā | ā | ā | ā | ā | ā | |||
parle* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
pcntl | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pcov | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
pdo_dblib | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pdo_firebird | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pdo_mysql | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pdo_oci | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
pdo_odbc | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pdo_pgsql | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pdo_sqlsrv | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
pgsql | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
phalcon | ā | ā | ā | ā | ā | ā | ā | |||||
php_trie | ā | ā | ā | ā | ā | ā | ā | |||||
phpy* | ā | ā | ā | ā | ||||||||
pkcs11 | ā | ā | ā | ā | ā | ā | ||||||
pq | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
propro | ā | ā | ā | ā | ā | ā | ā | |||||
protobuf | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pspell | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
psr | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
pthreads* | ā | ā | ā | |||||||||
raphf | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
rdkafka | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
recode | ā | ā | ā | ā | ā | ā | ||||||
redis | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
relay | ā | ā | ā | ā | ā | ā | ||||||
saxon* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
seasclick | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
seaslog | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
shmop | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
simdjson* | ā | ā | ā | ā | ā | ā | ā | ā | ā | |||
smbclient | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
snappy | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
snmp | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
snuffleupagus | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
soap | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sockets | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sodium* | ā | ā | ā | |||||||||
solr | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
sourceguardian | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
spx | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sqlsrv* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
ssh2 | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
stomp | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
swoole | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sybase_ct | ā | ā | ||||||||||
sync | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sysvmsg | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sysvsem | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
sysvshm | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
tensor | ā | ā | ā | ā | ā | ā | ||||||
tideways | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
tidy | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
timezonedb | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
uopz | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
uploadprogress | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
uuid | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
uv | ā | ā | ā | ā | ā | |||||||
vips* | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
vld | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | |
wddx | ā | ā | ā | ā | ā | ā | ||||||
wikidiff2* | ā | ā | ā | ā | ā | ā | ā | ā | ā | |||
xdebug | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
xdiff | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
xhprof | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
xlswriter | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
xmldiff | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
xmlrpc | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
xpass* | ā | ā | ā | ā | ā | |||||||
xsl | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
yac | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
yaml | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
yar | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
zephir_parser | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
zip | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
zmq | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
zookeeper | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ||
zstd | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā | ā |
Number of supported extensions: 152
PS: the pre-installed PHP extensions are excluded from this list.
You can list them with the following command (change php:7.2-cli
to reflect the PHP version you are interested in):
$ docker run --rm php:7.2-cli php -m
[PHP Modules]
Core
ctype
curl
date
dom
fileinfo
filter
ftp
hash
iconv
json
libxml
mbstring
mysqlnd
openssl
pcre
PDO
pdo_sqlite
Phar
posix
readline
Reflection
session
SimpleXML
sodium
SPL
sqlite3
standard
tokenizer
xml
xmlreader
xmlwriter
zlib
[Zend Modules]
Configuration
You can configure the behavior of the script, as well as fine-tune some extensions in order fit your needs, by using environment variables.
Here's an example:
IPE_LZF_BETTERCOMPRESSION=1 install-php-extensions lzf
Here's the list of all the supported environment variables:
Extension | Environment variable | Description |
---|---|---|
IPE_DEBUG=1 | By setting this environment variable, the script will print all the commands it executes (it will be very verbose, useful only for debug purposes) | |
IPE_PROCESSOR_COUNT | By default all available processors. Set this environment variable to override the number of processors detected by the script (used for parallel compilation) | |
IPE_DONT_ENABLE=1 | By default the script will install and enable the extensions. If you want to only install them (without enabling them) you can set this environment variable. To enable the extensions at a later time you can execute the command docker-php-ext-enable-<extension> (for example: docker-php-ext-enable-xdebug ).Beware: installing some PHP extensions requires that other PHP extensions are already enabled, so use this feature wisely. | |
IPE_SKIP_CHECK=1 | By default the script will check if the extensions can be enabled: if you want to skip this check, you can use this flag. Beware: extensions may be enabled even if they break PHP: use this function wisely. | |
IPE_KEEP_SYSPKG_CACHE=1 | By default the script will clear the apt/apk/pear cache in order to save disk space. You can disable it by setting this environment variable | |
lzf | IPE_LZF_BETTERCOMPRESSION=1 | By default install-php-extensions compiles the lzf extension to prefer speed over size; you can use this environment variable to compile it preferring size over speed |
event | IPE_EVENT_NAMESPACE= ... | By default, the event classes are defined in the root namespace. You can use this environment variable to specify a custom namespace |
gd | IPE_GD_WITHOUTAVIF=1 | Since PHP 8.1, gd supports the AVIF format. Enabling it requires compiling libaom/libdav1d/libyuv/libavif on Debian up to 11 and Alpine up to 3.14, which is time-consuming. You can disable AVIF support by setting this environment variable on those operating system versions |
oci8 & pdo_oci | IPE_INSTANTCLIENT_BASIC=1 | The oci8 and pdo_oci PHP extensions require Oracle Instant Client. In order to save disk space, we install the Basic Lite version: if you want to install the Basic (non-lite) version simply set this environment variable |
http, intl, mongodb | IPE_ICU_EN_ONLY=1 | Some extensions require the ICU library, use this flag to install a smaller, but English-only, ICU library on Alpine 3.16 and later |
pspell | IPE_ASPELL_LANGUAGES='...' | Configure the languages to be made available (for example: IPE_ASPELL_LANGUAGES='en fr' ). If omitted, we'll assume en |
IPE_DEB_ARCHIVE & IPE_DEB_ARCHIVE_SECURITY | The APT packages of very old Debian versions (eg Jessie) may have been archived: you can use these environment variables to specify custom URLs of these APT archives | |
newrelic | IPE_NEWRELIC_DAEMON=1 | Install the NewRelic daemon |
newrelic | IPE_NEWRELIC_KEEPLOG=1 | Keep the log files of NewRelic setup (/tmp/nrinstall-Ć¢ĀĀ¦.tar ) |
newrelic | NR_INSTALL_KEY | Your New Relic license key |
Special requirements
Some extensions have special requirements:
How do I know which Linux distribution I am using?
You can run this command:
cat /etc/os-release
For example:
- for Debian 11 (Bullseye) you'll see:
PRETTY_NAME="Debian GNU/Linux 11 (bullseye)"
- for Alpine Linux 3.14 you'll see:
PRETTY_NAME="Alpine Linux v3.14"
Tests
When submitting a pull request, a GitHub Action is executed to check if affected PHP extensions actually work (see below).
Furthermore, we also check that new versions of extensions in the PECL repository will still work.
This is done on a scheduled basis with another GitHub Action.
In case of failure, a message is sent to a Telegram Channel.
Feel free to subscribe to it to receive failure notifications.
How to contribute
Formatting code
Before submitting any pull request, you should execute the lint
script in the scripts
directory (or lint.bat
on Windows).
If you don't do that, and if there's a coding style error, you'll see that the Check shell coding style
and/or the Check PHP coding style
GitHub Actions will fail.
The error will be something like this:
--- filename.orig
+++ filename
@@ -line number,7 +line number,7 @@
good line of code #1
good line of code #2
good line of code #3
- the original line with a wrong coding style
+ the line wrong coding style that has been corrected
good line of code #4
good line of code #5
good line of code #6
So, you should fix highlighted line (the one(s) at line number
) by replacing what you see after the -
with what you see after the +
Adding support to a new PHP extension?
- change the
install-php-extensions
script - update the
data/supported-extensions
file, adding a new line with the handle of the extension and the list of supported PHP versions - if the extension requires ZTS images:
add a new line to thedata/special-requirements
file, with the extension handle followed by a space andzts
See this pull request for an example.
Changing the supported PHP versions for an already supported PHP extension?
- change the
install-php-extensions
script - update the
data/supported-extensions
file, adding the new PHP version to the existing line corresponding to the updated extension
See this pull request for an example.
Improving code for an already supported extension?
If you change some code that affects one or more extensions, please add a line with Test: extension1, extension2
to the message of one of the pull request commits.
That way, the test jobs will check the extension even if you don't touch the data/supported-extensions
file.
Here's an example of a commit message:
Improve the GD and ZIP extensions
Test: gd, zip
Tests only check the installation of a single PHP extension at a time. If you want to test installing more PHP extensions at the same time, use a commit message like this:
Improve the GD and ZIP extensions
Test: gd+zip
If your pull request contains multiple commits, we'll check the "Test:" message of every commit.
If you want to stop parsing next commits, add -STOP-
in the "Test:" line, for example:
Improve the GD and ZIP extensions
Test: gd, zip, -STOP-
See this pull request for an example.
PHP requirements and configure options
PHP extensions published on the PECL archive contain a package.xml
(or package2.xml
) file describing the supported PHP versions and the options that can be used to compile it.
When we add support for a new PHP extension, and when a new version of a PHP extension is released, we have to check those constraints.
It's a rather tedious task, so I developed a project that lets you easily check those constraints: you can find it at https://mlocati.github.io/pecl-info (here you can find its source code).
For the maintainers
See the MAINTAINERS.md
file.
Do you want to really say thank you?
You can offer me a monthly coffee or a one-time coffee :wink:
Top Related Projects
GitHub action to set up PHP with extensions, php.ini configuration, coverage drivers, and various tools.
Full PHP development environment for Docker.
š³ Production-ready Docker images for PHP. Optimized for Laravel, WordPress, and more!
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot