Files
Open-RSC-Docker-Home/README.md
Vincent Letourneau 671766bdf3 first commit
2017-01-15 15:48:31 +01:00

2.6 KiB

Nginx PHP MySQL

Docker running Nginx, PHP-FPM, MySQL and PHPMyAdmin.

THIS ENVIRONMENT SHOULD ONLY BE USED FOR DEVELOPMENT!

DO NOT USE IT IN PRODUCTION!

Images to use

Start using it

  1. Download it :

    git clone https://github.com/nanoninja/docker-nginx-php-mysql.git
    
  2. Run :

    $ docker-compose up -d
    
  3. Open your favorite browser :

Directory tree

.
├── bin
│   └── linux
│       └── clean.sh
├── data
│   └── db
│       ├── dumps
│       └── mysql
├── docker-compose.yml
├── etc
│   ├── nginx
│   │   └── default.conf
│   ├── php
│   │   └── php.ini
│   └── ssl
└── web
    ├── app
    │   ├── composer.json
    │   ├── src
    │   └── tests
    └── public
        └── index.php

Connecting from PDO

<?php
    $dsn = 'mysql:host=mysql;dbname=test;charset=utf8;port=3306';
    $pdo = new PDO($dsn, 'root', 'root');
?>

Updating composer

docker run --rm -v $(pwd)/web/app:/app -v ~/.ssh:/root/.ssh composer/composer update

MySQL Container shell access

docker exec -it mysql bash

and

$ mysql -uroot -proot

Creating database dumps

docker exec mysql sh -c 'exec mysqldump --all-databases -uroot -p"$MYSQL_ROOT_PASSWORD"' > /some/path/on/your/host/all-databases.sql

or

docker exec mysql sh -c 'exec mysqldump dbname -uroot -p"$MYSQL_ROOT_PASSWORD"' > /some/path/on/your/host/dbname.sql

Example

docker exec mysql sh -c 'exec mysqldump test -uroot -p"$MYSQL_ROOT_PASSWORD"' > $(pwd)/data/db/dumps/test.sql

Generating SSL certificates

  1. Generate certificates

    docker run --rm -v $(pwd)/etc/ssl:/certificates -e "SERVER=localhost" jacoelho/generate-certificate
    
  2. Configure Nginx

    Edit nginx file etc/nginx/default.conf and uncomment the server section.

    server {
        ...
    }
    

Cleaning project

./bin/linux/clean.sh $(pwd)