The following features work out of the box without any configuration:
bcmatchis installed for math/currency functionalitycomposeris installed for all your PHP dependenciesgdis installed for image processingintlis installed for internationalization and localization supportmsmtpis installed and configured (seeconfig/msmtprc) out of the box to send email toMailtrap.- Logs located at
/var/log/msmtp.log
- Logs located at
mysql_pdois installed as the driver for database connectionsNginxserves as the web host and reverse proxy- Logs located at
/var/log/nginx/
- Logs located at
npmandnodeare installed for all your Node dependencies and scriptspcntlis installed for process control (eg: Laravel Horizon)PHP-FPM/OPcachefor fast performance in the browser and on the CLIRedisextension is installed for cachingsupervisordis installed for process management (Starting with image version32)- By default, supervisor starts
php-fpmandnginx - Place any additional supervisord config in
/etc/supervisord/conf.d/*.conf - Logs located at
/var/log/supervisord.log
- By default, supervisor starts
zipis installed for items that may need it (eg: Laravel, CSV/Excel)
This image offers platform support for the following architectures starting from image version 8:
linux/amd64linux/arm/v7linux/arm64
# Dockerfile
FROM: justintime50/nginx-php:latest
# docker-compose
image: justintime50/nginx-php:latestdocker compose up -dOnce the container spins up, navigate to http://localhost:8888 in a browser.
Place your PHP or HTML site files into /var/www/html/public inside the container to get started with this image. This can be achieved by using a volume in a docker-compose file or by copying them over in a Dockerfile. If you are using HTML instead of PHP, ensure you remove the index.php file so that your index.html file can take priority.
Place the root of your laravel project in /var/www/html so that the public folder of laravel lines up with the directory served by this nginx image.
Tags for this image follow the syntax of PHP_VERSION-IMAGE_VERSION; for instance, a valid tag would be 8.2-16 signifying to use PHP v8.2 and the 16th version of this image (nginx config, Dockerfile, etc).
8.4- uses the latest release on the PHP 8.4 Alpine track. (Starting with image version21)8.3- uses the latest release on the PHP 8.3 Alpine track. (Starting with image version18)8.2- uses the latest release on the PHP 8.2 Alpine track. (Starting with image version12)8.1- uses the latest release on the PHP 8.1 Alpine track. (Starting with image version9)8.0- DEPRECATED uses the latest release on the PHP 8.0 Alpine track. (Dropped support with image version19)7.4- DEPRECATED uses the latest release on the PHP 7.4 Alpine track. (Dropped support with image version19)
See the CHANGELOG or the releases page for more details.
latest- uses the latest release (main branch) of this image with all defaults.dev- the testing branch for this image. Do not use this tag in production.
Note: Alpine Linux does not keep old versions of packages. This image pins to the relative major version to try staying flexibile. Future builds may need to be altered if packages are no longer offered.
# Test nginx configuration
nginx -TWhen releasing this project, cut a new GitHub tag/release that iterates the whole-number used (eg: 4, 5, 6, etc). We won't use semver here for simplicity when tagging images.
If you are adding a new PHP version, make sure to add it to the list in the GitHub Workflow files.
This image supports swapping in the version number of PHP with a value from the official PHP-FPM Alpine tag list.
GitHub Actions will automatically build and push supported tags to Docker Hub on each new release. Additionally GitHub Actions will automatically build the latest tag on any push to the main branch. It is highly recommended that you use a versioned release of this image to avoid any transient changes introduced in any given latest build.
docker build -t justintime50/nginx-php:8.0-7 --build-arg PHP_VERSION=8.0 .
sudo docker push justintime50/nginx-php:8.0-7msmtp is configured to work with Mailtrap out of the box. There is also a gmail template that you can uncomment and use in production. Spin up this container, then run the following to send mail directly with msmtp:
echo -e "Subject: Test email from msmtp\r\n\r\nThis is a test email direct from msmtp" |msmtp --debug --from from@example.com -t to@example.comYou can also send mail with PHP which routes the emails through msmtp:
php -r "mail('to@example.com','Test email from PHP', 'This is a test email from PHP');"