Nicolas Bonnici
Posted on February 17, 2024
Repository and post updated September 22 2024
The perfect Dockerized Symfony 6.4 boilerplate doesn't exists... But wait, what if I create and share my own vision of it?!!
Leggooo
We gonna build a classic stack that i personaly love, with such cutting edge technologies like PostgreSQL 16, Redis and Nginx HTTP server and also PHP 8.3 and FPM and Symfony framwork in LTS version 6.4.
First of all, I want something really easy to use, so let's leverage docker compose plugin without any extra argument to start and initialize all needed containers.
composer setup
Project treeview
- logs
- docker
- symfony
Everything is at project root to do so, no fancy parameter needed since everything use default project path convention.
Simply 3 folders, the first one "docker/" to store all Docker related configurations, one other "logs/" for the whole containers logs and a "symfony/" last one directory to put your Symfony project's source code.
Go further
Good but wait I have other developers to sync in that project and do they can scaffold it on their local development env without knowing any clue about Symfony and server side development or never work on containerized projects?
Nope just kidding, ain't no voodoo involved in that process, we're not gonna reinvent the wheel and make a revolution. Not at all, just a simple leverage of composer and more specially his scripts
section.
Ok if you don't rage quit this post or punch directly your screen you'll enjoy a little magic, with this simple one line command to run all needed containers then setup the database, create the data model before populating it if you agree the prompt by responding "yes" at the end.
All that using one dead simple command:
composer setup
Explanation we first build and launch all needed containers, the run them in demon mode, this the first part of the command: docker compose up --build -d
. The second part will then run the "install-project" composer script. See the symfony/composer.json
"scripts" section.
{
"scripts": {
...
"setup": [
"composer run up",
"composer run deps:install",
"composer run database",
"composer run migrate",
"composer run fixtures"
],
"up": [
"docker compose --env-file symfony/.env up -d --build"
],
"down": [
"docker compose --env-file symfony/.env down"
],
"stop": [
"docker compose --env-file symfony/.env stop"
],
"build": [
"docker compose --env-file symfony/.env build"
],
"deps:install": [
"docker exec -it php-fpm bin/composer install -o"
],
"database": [
"docker exec -it php-fpm bin/console doctrine:database:create -n --if-not-exists",
"docker exec -it php-fpm bin/console doctrine:database:create -n --if-not-exists --env=test"
],
"migrate": [
"docker exec -it php-fpm bin/console doctrine:migration:migrate -n",
"docker exec -it php-fpm bin/console doctrine:migration:migrate -n --env=test"
],
"fixtures": [
"docker exec -it php-fpm bin/console doctrine:fixtures:load -n",
"docker exec -it php-fpm bin/console doctrine:fixtures:load -n --env=test"
],
"tests": [
"docker exec -t php-fpm bash -c 'clear && ./vendor/bin/phpunit --testdox --exclude=smoke'"
],
"lint": [
"docker exec -t php-fpm ./vendor/bin/php-cs-fixer ./src/"
],
"lint:fix": [
"docker exec -t php-fpm ./vendor/bin/php-cs-fixer fix ./src/"
],
"db": [
"psql postgresql://postgres:password@127.0.0.1:15432/dbtest"
],
"logs": [
"docker compose logs -f"
],
"cache-clear": [
"docker exec -t php-fpm bin/console c:c"
]
}
}
It will first install all needed composer dependencies and optimize classes autoloader. Then execute migrations up to the latest version then populate database with fixtures respectively with "doctrine/doctrine-migrations-bundle" and "doctrine/doctrine-fixtures-bundle" bundles.
The actual composer scripts available:
composer [
setup
up
stop
build
deps:install
database
migrate
fixtures
tests: launch phpunit tests suite
lint
db: connect to database container via CLI client
logs: show containers logs
cache-clear
]
Talk is cheap, show me the code
Feel free to fork, contribute and maintain this boilerplate using this Gitlab repository: nicolasbonnici/symfony-docker-boilerplate
Posted on February 17, 2024
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.