Made by Martin Soenen & available on GitHub.
Containers created in a base of phpdocker.io.
Services installed in this boilerplate | Installation container |
---|---|
PHP & PHP-FPM | php |
NGINX | nginx |
MySQL | mysql |
PHPMyAdmin | phpmyadmin |
Composer | php |
Node & NPM | php |
MailHog | mailhog |
Fill in the variable names in the .env
file specific to your project.
Build the Docker containers : docker-compose build
.
Once this is done, you can run the containers : docker-compose up -d
.
At the first launch after building the containers, wait a few seconds for MySQL to launch properly.
To install Symfony, you need to run a composer command : docker-compose exec php composer create-project symfony/website-skeleton my-project
.
Note : if you want to install Symfony 4.4, you should run docker-compose exec php composer create-project symfony/website-skeleton:^4.4 my-project
instead of the one above.
Now you can find a folder called my-project
, and Symfony is inside. Just move the files from this folder to the boilerplate base and delete the my-project
folder because it is now empty. Make sure to not replace the .env file, you have to merge it to keep the contents of the 2 .env files.
Now, you need to set the database address in the .env file. So you have to replace DATABASE_URL=mysql://db_user:db_password@127.0.0.1:3306/db_name?serverVersion=5.7
by DATABASE_URL="mysql://${MYSQL_USER}:${MYSQL_PASSWORD}@mysql:3306/${DATABASE_NAME}"
The project is now available if you go to the URL localhost
!
If you want to have a better URL, you can add the following line to your hosts file 127.0.0.1 ${PROJECT_URL}
and the project will be available on the URL you set in the PROJECT_URL line of your .env file !
You can put your project files at the root of this boilerplate.
To access PHPMyAdmin, just go to the port 81 of your project.
To access MailHog, just go to the port 82 of your project.
For obvious security reasons, it is not recommended to use these ports for a production environment.
To access Composer, Node or NPM, you must enter the PHP container : docker-compose exec php bash
. You will then be able to do your Composer/Node/NPM commands.
Be careful, the IP address of the database is the name of the container. The address to indicate in the configuration files of your framework/CMS is therefore : mysql
.
- Start the containers by watching their logs :
docker-compose up
- Start the containers in the background :
docker-compose up -d
- Stop the containers :
docker-compose stop
- Kill the containers :
docker-compose kill
- Delete the containers :
docker-compose rm
- Stop and delete the containers :
docker-compose down
- Check the status of the containers :
docker-compose ps
- Watch the container logs :
docker-compose logs
- Making a command in a container :
docker-compose exec CONTAINER_NAME COMMAND
whereCOMMAND
is your command. Examples :- Open a console in the php-fpm container :
docker-compose exec php bash
- Open the Symfony console :
docker-compose exec php bin/console
- Open a console in the php-fpm container :