• Stars
    star
    1,307
  • Rank 35,997 (Top 0.8 %)
  • Language
    Dockerfile
  • License
    MIT License
  • Created over 8 years ago
  • Updated over 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

🐳 A docker multicontainer with NGINX, PHP7-FPM, MySQL and ELK (Elasticsearch Logstash and Kibana)

Docker Symfony (PHP7-FPM - NGINX - MySQL - ELK)

Build Status

Docker-symfony gives you everything you need for developing Symfony application. This complete stack run with docker and docker-compose (1.7 or higher).

Installation

  1. Create a .env from the .env.dist file. Adapt it according to your symfony application

    cp .env.dist .env
  2. Build/run containers with (with and without detached mode)

    $ docker-compose build
    $ docker-compose up -d
  3. Update your system host file (add symfony.local)

    # UNIX only: get containers IP address and update host (replace IP according to your configuration) (on Windows, edit C:\Windows\System32\drivers\etc\hosts)
    $ sudo echo $(docker network inspect bridge | grep Gateway | grep -o -E '([0-9]{1,3}\.){3}[0-9]{1,3}') "symfony.local" >> /etc/hosts

    Note: For OS X, please take a look here and for Windows read this (4th step).

  4. Prepare Symfony app

    1. Update app/config/parameters.yml

      # path/to/your/symfony-project/app/config/parameters.yml
      parameters:
          database_host: db
    2. Composer install & create database

      $ docker-compose exec php bash
      $ composer install
      # Symfony2
      $ sf doctrine:database:create
      $ sf doctrine:schema:update --force
      # Only if you have `doctrine/doctrine-fixtures-bundle` installed
      $ sf doctrine:fixtures:load --no-interaction
      # Symfony3
      $ sf3 doctrine:database:create
      $ sf3 doctrine:schema:update --force
      # Only if you have `doctrine/doctrine-fixtures-bundle` installed
      $ sf3 doctrine:fixtures:load --no-interaction
  5. Enjoy :-)

Usage

Just run docker-compose up -d, then:

Customize

If you want to add optionnals containers like Redis, PHPMyAdmin... take a look on doc/custom.md.

How it works?

Have a look at the docker-compose.yml file, here are the docker-compose built images:

  • db: This is the MySQL database container,
  • php: This is the PHP-FPM container in which the application volume is mounted,
  • nginx: This is the Nginx webserver container in which application volume is mounted too,
  • elk: This is a ELK stack container which uses Logstash to collect logs, send them into Elasticsearch and visualize them with Kibana.

This results in the following running containers:

$ docker-compose ps
           Name                          Command               State              Ports            
--------------------------------------------------------------------------------------------------
dockersymfony_db_1            /entrypoint.sh mysqld            Up      0.0.0.0:3306->3306/tcp      
dockersymfony_elk_1           /usr/bin/supervisord -n -c ...   Up      0.0.0.0:81->80/tcp          
dockersymfony_nginx_1         nginx                            Up      443/tcp, 0.0.0.0:80->80/tcp
dockersymfony_php_1           php-fpm                          Up      0.0.0.0:9000->9000/tcp      

Useful commands

# bash commands
$ docker-compose exec php bash

# Composer (e.g. composer update)
$ docker-compose exec php composer update

# SF commands (Tips: there is an alias inside php container)
$ docker-compose exec php php /var/www/symfony/app/console cache:clear # Symfony2
$ docker-compose exec php php /var/www/symfony/bin/console cache:clear # Symfony3
# Same command by using alias
$ docker-compose exec php bash
$ sf cache:clear

# Retrieve an IP Address (here for the nginx container)
$ docker inspect --format '{{ .NetworkSettings.Networks.dockersymfony_default.IPAddress }}' $(docker ps -f name=nginx -q)
$ docker inspect $(docker ps -f name=nginx -q) | grep IPAddress

# MySQL commands
$ docker-compose exec db mysql -uroot -p"root"

# F***ing cache/logs folder
$ sudo chmod -R 777 app/cache app/logs # Symfony2
$ sudo chmod -R 777 var/cache var/logs var/sessions # Symfony3

# Check CPU consumption
$ docker stats $(docker inspect -f "{{ .Name }}" $(docker ps -q))

# Delete all containers
$ docker rm $(docker ps -aq)

# Delete all images
$ docker rmi $(docker images -q)

FAQ

  • Got this error: ERROR: Couldn't connect to Docker daemon at http+docker://localunixsocket - is it running? If it's at a non-standard location, specify the URL with the DOCKER_HOST environment variable. ?
    Run docker-compose up -d instead.

  • Permission problem? See this doc (Setting up Permission)

  • How to config Xdebug? Xdebug is configured out of the box! Just config your IDE to connect port 9001 and id key PHPSTORM

Contributing

First of all, thank you for contributing ♥
If you find any typo/misconfiguration/... please send me a PR or open an issue. You can also ping me on twitter.
Also, while creating your Pull Request on GitHub, please write a description which gives the context and/or explains why you are creating it.

More Repositories

1

gatsby-starter-morning-dew

🚀 A Gatsby theme/starter to build lightning-fast blog/websites
JavaScript
204
star
2

dotfiles

💻 my dotfiles (MacOS)
Shell
33
star
3

vue-testing-library-sample

🚀 A Vue.js project to test Jest and Testing-library. Data come from Star Wars API.
Vue
20
star
4

design-pattern-php

Some Design Pattern implemented in PHP
PHP
10
star
5

maxpou.fr

🌐 Maxpou's personal website
MDX
9
star
6

gitvub

:octocat: Github + Vue = GitVub
JavaScript
5
star
7

graphql-nodejs-mongodb

POC with GraphQL, NodeJS and MongoDB
JavaScript
5
star
8

symfony-rest-beer-edition

🍻 A Symfony application with a REST API
PHP
4
star
9

pikaday-vue

A Vue.js wrapper for Pikaday
JavaScript
3
star
10

nest-react-graphql

A React&NestJS application that integrates with GraphQL.
TypeScript
3
star
11

gatsby-groot

sample using gatsby-starter-morning-dew theme
JavaScript
3
star
12

happy-halloween

🎃 Set a halloween theme to your website
HTML
3
star
13

silex-boilerplate

A lightweight Silex application which provide an API with HAL/HATEOAS
PHP
2
star
14

dictionary-game

📔 A dictionary mini game
Vue
2
star
15

hubot-docker

🐳 A docker file for my Hubot
1
star
16

analyticsCNIL

JavaScript
1
star
17

sebastiandedeyne.com

My personal website, built with Hugo
HTML
1
star
18

maxpou

My GitHub profile
1
star
19

vscode-extension-maxpou

1
star
20

swapi-shop-vue-vuex

🚀 A Vue.js + Vuex project using the StarWars API
JavaScript
1
star
21

pomodoro-ninja.gadget

⌚ a MS Windows Gadget for Pomodoro Technique
JavaScript
1
star
22

hermes

✈️ playing with @Mapbox
JavaScript
1
star
23

github-actions-test

playing with GiHub Actions
JavaScript
1
star
24

gatsby-theme-resume

JavaScript
1
star
25

gatsby-themes-tutorial

JavaScript
1
star