Skip to content

martinsoenen/Docker-Boilerplate-Symfony

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Docker Boilerplate

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

First install

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.

Accessing services

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.

Docker-compose cheatsheet

  • 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 where COMMAND 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