Docker symfony gives you everything you need for developing Symfony application. This complete stack run with docker and docker-compose.
If you are running on Linux:
curl -fsSL https://get.docker.com -o get-docker.sh &&
sh get-docker.sh
If you would like to use Docker as a non-root user, you should now consider adding your user to the "docker" group with something like:
sudo usermod -aG docker ${USER}
If you are running on Linux:
sudo curl -L "https://github.com/docker/compose/releases/download/v2.28.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose && sudo chmod +x /usr/local/bin/docker-compose
-
Create a
.env
from the.env.dist
file. Adapt it according to your symfony applicationcp .env.dist .env
-
Build / run containers
./d4d start
-
Update your system host file (add symfony.local)
# UNIX only: get containers IP address and update host (replace IP according to your configuration) $ sudo echo $(docker network inspect bridge | grep Gateway | grep -o -E '[0-9\.]+') "symfony.local" >> /etc/hosts
Note: For OS X, please take a look here.
-
Prepare Symfony app
-
Get your logins to access MySQL server
./d4d passwd show
-
Update
a) SF2, SF3: app/config/parameters.yml
# ./project/app/config/parameters.yml parameters: database_host: mysql database_port: ~ database_name: db_name database_user: db_user database_password: db_password (random password)
b) SF4, SF5, SF6: .env
DATABASE_URL=mysql://db_user:db_password@mysql:3306/db_name MAILER_URL=smtp://mailhog:1025
-
Composer install & create database
$ docker-compose exec php bash $ composer create-project symfony/website-skeleton my-project # Symfony 2 $ sf doctrine:database:create $ sf doctrine:schema:update --force # Only if you have `doctrine/doctrine-fixtures-bundle` installed $ sf doctrine:fixtures:load --no-interaction # Symfony 3 $ sf3 doctrine:database:create $ sf3 doctrine:schema:update --force # Only if you have `doctrine/doctrine-fixtures-bundle` installed $ sf3 doctrine:fixtures:load --no-interaction # Symfony 4 $ sf4 doctrine:database:create $ sf4 doctrine:schema:update --force # Only if you have `doctrine/doctrine-fixtures-bundle` installed $ sf4 doctrine:fixtures:load --no-interaction # Symfony 5 $ sf5 doctrine:database:create $ sf5 doctrine:schema:update --force # Only if you have `doctrine/doctrine-fixtures-bundle` installed $ sf5 doctrine:fixtures:load --no-interaction # Symfony 6 $ sf6 doctrine:database:create $ sf6 doctrine:schema:update --force # Only if you have `doctrine/doctrine-fixtures-bundle` installed $ sf6 doctrine:fixtures:load --no-interaction
-
-
Enjoy :-)
Just run
./d4d start
, then:- Symfony app: visit symfony.local
- Symfony dev mode: visit symfony.local/app_dev.php
- Logs (files location): logs/nginx and logs/symfony
Have a look at the
compose.yaml
file, here are thedocker-compose
built images:nginx
: Nginx is one of the most popular web servers in the world and responsible for hosting some of the largest and highest-traffic sites on the internet. It is more resource-friendly than Apache in most cases and can be used as a web server or reverse proxy.php
: PHP is a popular general-purpose scripting language that is especially suited to web development.mysql:
MySQL is the most popular relational database management system.phpmyadmin
: phpMyAdmin was created so that users can interact with MySQL / MariaDB through a web interface.mailhog
: MailHog is an email testing tool for developers.redis
: Redis is an open source (BSD licensed), in-memory data structure store, used as a database, cache and message broker. It supports data structures such as strings, hashes, lists, sets, sorted sets with range queries, bitmaps, hyperloglogs, geospatial indexes with radius queries and streams. Redis has built-in replication, Lua scripting, LRU eviction, transactions and different levels of on-disk persistence, and provides high availability via Redis Sentinel and automatic partitioning with Redis Cluster.
This results in the following running containers:
$ docker-compose ps Name Command State Ports --------------------------------------------------------------------------------------------------------------------- docker-symfony_mailhog_1 MailHog Up 0.0.0.0:1025->1025/tcp, 0.0.0.0:8025->8025/tcp docker-symfony_mysql_1 docker-entrypoint.sh --cha ... Up 0.0.0.0:3306->3306/tcp docker-symfony_nginx_1 nginx -g daemon off; Up 0.0.0.0:80->80/tcp docker-symfony_php_1 docker-php-entrypoint php-fpm Up 9000/tcp docker-symfony_phpmyadmin_1 /docker-entrypoint.sh apac ... Up 0.0.0.0:8080->80/tcp docker-symfony_redis_1 docker-entrypoint.sh redis ... Up 6379/tcp
Extension | PHP 7.1 | PHP 7.2 | PHP 7.3 | PHP 7.4 | PHP 8.0 | PHP 8.1 | PHP 8.2 | PHP 8.3 |
---|---|---|---|---|---|---|---|---|
amqp | 1.11.0 | 1.11.0 | 1.11.0 | 2.1.1 | 2.1.1 | 2.1.1 | 2.1.1 | 2.1.1 |
mongodb | 1.11.1 | 1.16.2 | 1.16.2 | 1.17.1 | 1.17.1 | 1.17.1 | 1.17.1 | 1.17.1 |
redis | 5.3.7 | 6.0.2 | 6.0.2 | 6.0.2 | 6.0.2 | 6.0.2 | 6.0.2 | 6.0.2 |
xdebug | 2.9.8 | 3.1.6 | 3.1.6 | 3.1.6 | 3.1.6 | 3.1.6 | 3.1.6 | 3.1.6 |