/docker-php7

Docker image tailed to run PHP application

Primary LanguageDockerfileMIT LicenseMIT

docker-php7

Docker image tailored to run PHP application. Check https://hub.docker.com/r/touch4it/docker-php7

What's here?

This repository is a source code for following Docker images that allow relatively easily work with PHP frameworks. Included images:

  • Debian + Apache + mod_php
    • touch4it/docker-php7:php7.2-apache
    • touch4it/docker-php7:php7.3-apache
    • touch4it/docker-php7:php7.4-apache
  • Debian + Apache + PHP-FPM
    • touch4it/docker-php7:php7.3-fpm-apache
    • touch4it/docker-php7:php7.4-fpm-apache
  • Alpine + Nginx + PHP-FPM
    • touch4it/docker-php7:php7.2-fpm-nginx
    • touch4it/docker-php7:php7.2-fpm-nginx-dev
    • touch4it/docker-php7:php7.3-fpm-nginx
    • touch4it/docker-php7:php7.3-fpm-nginx-dev
    • touch4it/docker-php7:php7.4-fpm-nginx
    • touch4it/docker-php7:php7.4-fpm-nginx-dev
  • Symfony
    • touch4it/php7-apache-symfony:php7.2
    • touch4it/php7-apache-symfony:php7.3
    • touch4it/php7-apache-symfony:php7.4
    • touch4it/php-nginx-symfony:php7.2-fpm-nginx
    • touch4it/php-nginx-symfony:php7.2-fpm-nginx-dev
    • touch4it/php-nginx-symfony:php7.3-fpm-nginx
    • touch4it/php-nginx-symfony:php7.3-fpm-nginx-dev
    • touch4it/php-nginx-symfony:latest, php7.4-fpm-nginx
    • touch4it/php-nginx-symfony:php7.4-fpm-nginx-dev
  • Drupal
    • touch4it/drupal-php-fpm-nginx:latest, 9.0.1, 9.0
    • touch4it/drupal-php-fpm-nginx:8.9.1, 8.9, 8.9-php7.3
    • touch4it/drupal-php-fpm-nginx:8.9-php7.4
    • touch4it/drupal-php-fpm-nginx:8.8.8, 8.8, 8.8-php7.3
    • touch4it/drupal-php-fpm-nginx:8.8-php7.4
  • Drupal console
    • touch4it/drupal-php-fpm-nginx:console
  • Symfony
    • touch4it/php7-apache-symfony:php7.2
    • touch4it/php7-apache-symfony:php7.3
    • touch4it/php7-apache-symfony:php7.4
    • touch4it/php-nginx-symfony:php7.2-fpm-nginx
    • touch4it/php-nginx-symfony:php7.2-fpm-nginx-dev
    • touch4it/php-nginx-symfony:php7.3-fpm-nginx
    • touch4it/php-nginx-symfony:php7.3-fpm-nginx-dev
    • touch4it/php-nginx-symfony:latest, php7.4-fpm-nginx
    • touch4it/php-nginx-symfony:php7.4-fpm-nginx-dev
  • Yii2
    • touch4it/yii2-php-fpm-nginx:7
    • touch4it/yii2-php-fpm-nginx:7.1, latest
    • touch4it/yii2-php-fpm-nginx:7.2
    • touch4it/yii2-php-fpm-nginx:7-dev
    • touch4it/yii2-php-fpm-nginx:7.1-dev
    • touch4it/yii2-php-fpm-nginx:7.2-dev

Usage

Development env with docker-compose.yml

You can you this docker-compose.yml file to develop:

www:
  image: touch4it/docker-php7:latest
  volumes:
    - ".:/var/www/html"
  ports:
    - "80"

Of course, you are free to add linked containers like database, caching etc.

Use docker-compose up command to start your development environment.

Build production image

You can build production ready image with Dockerfile like this:

FROM touch4it/docker-php7:latest
ADD . /var/www/html

Environment variables

This image uses several environment variables which are easy to miss. While none of the variables are required, they may significantly aid you in using the image.

ADMIN_EMAIL

The ServerAdmin sets the contact address that the server includes in any error messages it returns to the client. If the httpd doesn't recognize the supplied argument as an URL, it assumes, that it's an email-address and prepends it with mailto: in hyperlink targets. However, it's recommended to actually use an email address, since there are a lot of CGI scripts that make that assumption. If you want to use an URL, it should point to another server under your control. Otherwise users may not be able to contact you in case of errors.

Default value: webmaster@localhost

For Apache-based images

PHP_TIME_ZONE

Defines the default timezone used by the date functions

http://php.net/date.timezone

Default value: Europe/London

PHP_MEMORY_LIMIT

Maximum amount of memory a script may consume

http://php.net/memory-limit

Default value: 256M

PHP_UPLOAD_MAX_FILESIZE

Maximum allowed size for uploaded files.

http://php.net/upload-max-filesize

Default value: 32M

PHP_POST_MAX_SIZE

Maximum size of POST data that PHP will accept. Its value may be 0 to disable the limit. It is ignored if POST data reading is disabled through enable_post_data_reading.

http://php.net/post-max-size

Default value: 32M

FAQ

What extensions are enabled by default?

Apache

  • mod_rewrite

For Apache-based images

  • mod_http2

for Apache 2.4.26+ based images

PHP

  • bcmath
  • exif
  • gd
  • gettext
  • intl
  • mbstring
  • opcache
  • pgsql
  • pdo
  • pdo_mysql
  • pdo_pgsql
  • zip

How do I install additional php extensions?

This work is based on official Docker Hub php images. You can use docker-php-ext-install to add new extensions. More information can be found https://hub.docker.com/_/php/

How do I change default PHP variables?

You can add an ini file into $PHP_INI_DIR/conf.d directory

Why is my .htaccess file not working?

Check if you have not selected Nginx-based image

What Apache version is on Apache-based images?

Same as in similar official PHP image on Docker Hub

What Nginx version is on Nginx-based images?

1.16.1