Compare commits
15 Commits
Author | SHA1 | Date | |
---|---|---|---|
daa5ed981f | |||
9ac7541dc9 | |||
05a83d383f | |||
12051834a3 | |||
e2593ab522 | |||
4f9271d565 | |||
c447eb86e4 | |||
530ffe7433 | |||
c8718e3746 | |||
feaff6fa72 | |||
d98cf4754b | |||
b335364591 | |||
105fce8965 | |||
0973aaf166 | |||
b5be47fb5e |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
/logs
|
383
README.md
383
README.md
@ -3,27 +3,45 @@
|
|||||||
[](http://www.zalt.me)
|
[](http://www.zalt.me)
|
||||||
|
|
||||||
|
|
||||||
|
LaraDock helps you run your **Laravel** App on **Docker** real quick.
|
||||||
Like Laravel Homstead but for Docker instead of Vagrant.
|
|
||||||
<br>
|
<br>
|
||||||
LaraDock helps you run your **Laravel** App on **Docker** in seconds.
|
It's like Laravel Homestead but for Docker instead of Vagrant.
|
||||||
|
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
## Contents
|
## Contents
|
||||||
|
|
||||||
|
|
||||||
- [Intro](#Intro)
|
- [Intro](#Intro)
|
||||||
|
- [Default Containers](#Default-Containers)
|
||||||
- [Requirements](#Requirements)
|
- [Requirements](#Requirements)
|
||||||
|
- [Installation](#Installation)
|
||||||
- [Usage](#Usage)
|
- [Usage](#Usage)
|
||||||
- [Documentation](#Documentation)
|
- [Documentation](#Documentation)
|
||||||
- [Docker Images](#Images)
|
- [List current running Containers](#List-current-running-Containers)
|
||||||
|
- [Close all running Containers](#Close-all-running-Containers)
|
||||||
|
- [Delete all existing Containers](#Delete-all-existing-Containers)
|
||||||
|
- [Build/Re-build Containers](#Build-Re-build-Containers)
|
||||||
|
- [Use Redis in Laravel](#Use-Redis-in-Laravel)
|
||||||
|
- [Use custom Domain](Use-custom-Domain)
|
||||||
|
- [Change the PHP Version](#Change-the-PHP-Version)
|
||||||
|
- [Add/Remove a Docker Container](#AddRemove-a-Docker-Container)
|
||||||
|
- [Add more Software's (Docker Images)](#Add-Docker-Images)
|
||||||
|
- [Edit a Docker Container](#Edit-a-Docker-Container)
|
||||||
|
- [View the Log files](#View-the-Log-files)
|
||||||
|
- [Enter a Container (SSH into a running Container)](#Enter-Container)
|
||||||
|
- [Edit a Docker Image](#Edit-a-Docker-Image)
|
||||||
|
- [Run a Docker Virtual Host](#Run-Docker-Virtual-Host)
|
||||||
|
- [Find your Docker IP Address](#Find-Docker-IP-Address)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="Intro"></a>
|
<a name="Intro"></a>
|
||||||
### Intro
|
## Intro
|
||||||
|
|
||||||
LaraDock strives to make the development experience easier.
|
LaraDock strives to make the development experience easier.
|
||||||
It contains pre-packaged Docker Images that provides you a wonderful development environment without requiring you to install PHP, NGINX, MySQL, REDIS, and any other software on your local machine.
|
It contains pre-packaged Docker Images that provides you a wonderful development environment without requiring you to install PHP, NGINX, MySQL, REDIS, and any other software on your local machine.
|
||||||
@ -44,25 +62,14 @@ Seriously!!!
|
|||||||
Instead of providing a full Virtual Machines, like you get with Vagrant, Docker provides you **lightweight** Virtual Containers, that share the same kernel and allow to safely execute independent processes.
|
Instead of providing a full Virtual Machines, like you get with Vagrant, Docker provides you **lightweight** Virtual Containers, that share the same kernel and allow to safely execute independent processes.
|
||||||
|
|
||||||
|
|
||||||
### Questions?
|
<a name="Default-Containers"></a>
|
||||||
[](https://gitter.im/LaraDock/laradock?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
## Default Containers
|
||||||
|
|
||||||
|
- PHP
|
||||||
|
- NGINX
|
||||||
<a name="Images"></a>
|
|
||||||
## Supported Software (Docker Images)
|
|
||||||
|
|
||||||
- PHP 5.6 / NGINX
|
|
||||||
- PHP 5.5 / NGINX
|
|
||||||
- MySQL
|
- MySQL
|
||||||
- Redis
|
- Redis
|
||||||
- Data Volume (for MySQL & Redis)
|
- Data Volume
|
||||||
- Beanstalked
|
|
||||||
|
|
||||||
|
|
||||||
The Images links on [Github](https://github.com/LaraDock)
|
|
||||||
<br>
|
|
||||||
The Images links on [Docker Hub](https://hub.docker.com/u/laradock/)
|
|
||||||
|
|
||||||
|
|
||||||
<a name="Requirements"></a>
|
<a name="Requirements"></a>
|
||||||
@ -72,108 +79,86 @@ The Images links on [Docker Hub](https://hub.docker.com/u/laradock/)
|
|||||||
- Git ([Download](https://git-scm.com/downloads))
|
- Git ([Download](https://git-scm.com/downloads))
|
||||||
- Composer ([Download](https://getcomposer.org/download/))
|
- Composer ([Download](https://getcomposer.org/download/))
|
||||||
|
|
||||||
|
<a name="Installation"></a>
|
||||||
|
## Installation
|
||||||
|
|
||||||
<a name="Usage"></a>
|
1 - Clone the `LaraDock` repository, in any of your `Laravel` projects:
|
||||||
## Usage
|
|
||||||
|
|
||||||
1 - Install any version of Laravel, or use any of your existing Laravel projects.
|
|
||||||
|
|
||||||
2 - Clone the LaraDock repository, inside a `docker` folder, on the root directory of your Laravel project.
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
git clone https://github.com/LaraDock/laradock.git docker
|
git clone https://github.com/LaraDock/laradock.git docker
|
||||||
```
|
```
|
||||||
|
|
||||||
3 - Find your Docker IP address.
|
Instead of `git clone` you can use `git submodule add` in case you are already using Git for your Laravel project *(Recommended)*:
|
||||||
|
|
||||||
- If you are on Linux OS: your IP Address is `127.0.0.1` because the containers run directly on your localhost.
|
|
||||||
- If you are on MAC or Windows and using the **docker-machine**: start your docker machine then type `docker-machine ip {vm-name-here}`. *(The default IP is 192.168.99.100)*
|
|
||||||
- If you are on MAC or Windows and using **boot2docker**: type `boot2docker ip` when boot2docker is up.
|
|
||||||
|
|
||||||
4 - Open your hosts file `/etc/hosts`.
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
sudo nano /etc/hosts
|
git submodule add https://github.com/LaraDock/laradock.git docker
|
||||||
```
|
```
|
||||||
|
|
||||||
5 - Map your `Docker IP` to the `laravel.dev` domain, by adding the following to the `hosts` file.
|
>These commands should create a `docker` folder, on the root directory of your Laravel project.
|
||||||
|
|
||||||
```bash
|
|
||||||
xxx.xxx.xxx.xxx laravel.dev
|
|
||||||
```
|
|
||||||
|
|
||||||
Don't forget to replace the `xxx.xxx.xxx.xxx` with your Docker IP Address.
|
<a name="Usage"></a>
|
||||||
|
## Usage
|
||||||
|
|
||||||
6 - From the new created `docker` folder in step 2, open the `docker-compose.yml` file to replace the `xxx.xxx.xxx.xxx` with your Docker IP Adress as well.
|
>**(Windows & MAC users)** Make sure you have a running Docker Virtual Host on your machine first.
|
||||||
|
><br>
|
||||||
|
>[How to run a Docker Virtual Host?](#Run-Docker-Virtual-Host)
|
||||||
|
|
||||||
7 - Open your Laravel's `.env` file and set the `DB_HOST` and the `REDIS_HOST` to `laravel.dev` instead of the default `127.0.0.1`.
|
|
||||||
|
<br>
|
||||||
|
1 - Open your Laravel's `.env` file and set the `DB_HOST` to your `{Docker-IP}`:
|
||||||
|
|
||||||
```env
|
```env
|
||||||
DB_HOST=laravel.dev
|
DB_HOST=xxx.xxx.xxx.xxx
|
||||||
REDIS_HOST=laravel.dev
|
|
||||||
```
|
```
|
||||||
|
[How to find my Docker IP Address?](#Find-Docker-IP-Address)
|
||||||
|
|
||||||
If you don't find the `REDIS_HOST` variable in your `.env` file. Go to the database config file `config/database.php` and replace the `127.0.0.1` with `laravel.dev` for Redis like so:
|
<br>
|
||||||
|
2 - Run the containers:
|
||||||
```php
|
<br>
|
||||||
'redis' => [
|
*(Make sure you are in the `docker` folder before running this command)*
|
||||||
'cluster' => false,
|
|
||||||
'default' => [
|
|
||||||
'host' => 'laravel.dev',
|
|
||||||
'port' => 6379,
|
|
||||||
'database' => 0,
|
|
||||||
],
|
|
||||||
],
|
|
||||||
```
|
|
||||||
|
|
||||||
If you want to use Redis for Caching and/or for Sessions Management. Open the `.env` file and set `CACHE_DRIVER` and `SESSION_DRIVER` to `redis` instead of the default `file`.
|
|
||||||
|
|
||||||
```env
|
|
||||||
CACHE_DRIVER=redis
|
|
||||||
SESSION_DRIVER=redis
|
|
||||||
```
|
|
||||||
|
|
||||||
8 - Finally run the containers. **Make sure you are in the `docker` folder** before running this command.
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker-compose up -d
|
docker-compose up -d
|
||||||
```
|
```
|
||||||
|
|
||||||
You can run `docker-compose up` (without **-d**) if you don't want to run the containers in the background.
|
>*Only the first time you run this command, it will take up to 5 minutes (depend on your connection speed) to download the Docker Images on your local machine.*
|
||||||
|
|
||||||
*"Note: Only the first time you run this command, it will take up to 5 minutes (depend on your connection speed) to download the images to your local machine.*
|
<br>
|
||||||
|
3 - Open your browser and visit your `{Docker-IP}` address (`http://xxx.xxx.xxx.xxx`).
|
||||||
> Debugging: in case you faced a problem with the docker mahcine here, run this command in your current terminal session `eval "$(docker-machine env {vm-name-here})"`.
|
|
||||||
|
|
||||||
|
|
||||||
9 - Open your browser and visit `http://laravel.dev`
|
> **Debugging**: in case you faced an error here, run this command from the Laravel root directory:
|
||||||
|
> <br>
|
||||||
|
> `sudo chmod -R 777 storage && sudo chmod -R 777 bootstrap/cache`
|
||||||
> Debugging: in case you faced an error here, it might be that you forget to provide some permissions for Laravel, so try running the following command on the Laravel root directory:
|
|
||||||
`sudo chmod -R 777 storage && sudo chmod -R 777 bootstrap/cache`.
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
|
||||||
|
|
||||||
[Follow @Mahmoud_Zalt](https://twitter.com/Mahmoud_Zalt)
|
[Follow @Mahmoud_Zalt](https://twitter.com/Mahmoud_Zalt)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Documentation"></a>
|
<a name="Documentation"></a>
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
||||||
#### See current running Containers
|
<a name="List-current-running-Containers"></a>
|
||||||
|
#### List current running Containers
|
||||||
```bash
|
```bash
|
||||||
docker ps
|
docker ps
|
||||||
```
|
```
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
<a name="Close-all-running-Containers"></a>
|
||||||
#### Close all running Containers
|
#### Close all running Containers
|
||||||
```bash
|
```bash
|
||||||
docker-compose stop
|
docker-compose stop
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
<a name="Delete-all-existing-Containers"></a>
|
||||||
#### Delete all existing Containers
|
#### Delete all existing Containers
|
||||||
```bash
|
```bash
|
||||||
docker-compose rm -f
|
docker-compose rm -f
|
||||||
@ -184,52 +169,125 @@ docker-compose rm -f
|
|||||||
`docker stop {container-name}`
|
`docker stop {container-name}`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
#### Change the PHP Version
|
<a name="Build-Re-build-Containers"></a>
|
||||||
By default **PHP 5.6** is running.
|
#### Build/Re-build Containers
|
||||||
<br>
|
```bash
|
||||||
To change the default PHP version, simply open your `docker-compose.yml` file and edit this line:
|
docker-compose build
|
||||||
|
|
||||||
```yaml
|
|
||||||
image: laradock/php56nginx:0.1.0
|
|
||||||
```
|
```
|
||||||
Supported versions:
|
|
||||||
|
|
||||||
- (PHP 5.5.*) laradock/php55nginx:latest
|
|
||||||
- (PHP 5.6.*) laradock/php56nginx:latest
|
|
||||||
|
|
||||||
|
|
||||||
**Note:**
|
|
||||||
|
|
||||||
If you set `laradock/phpnginx` as your image, this will pull from `laradock/php56nginx`.
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
|
||||||
#### Upgrade the docker images
|
|
||||||
|
|
||||||
By default `docker-compose.yml` is configured to use the latest stable version of the image (latest stable realease `tag`).
|
|
||||||
|
|
||||||
|
|
||||||
To use the latest build you can edit the `docker-compose.yml` file and replace the version number at the end of every image name with `:latest`
|
|
||||||
<br>
|
|
||||||
Example: change `image: laradock/mysql:0.1.0` to `image: laradock/mysql:latest`
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
|
||||||
#### Remove Container
|
|
||||||
To prevent a container (software) from running, open the `docker-compose.yml` file, and comment out the container section or remove it entirely.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
#### Add an Image (add a software to run with other Containers)
|
<a name="Use-Redis-in-Laravel"></a>
|
||||||
To add an image (software), just edit the `docker-compose.yml` and add your container details, to do so you need to be familiar with the [docker compose file syntax](https://docs.docker.com/compose/yml/).
|
#### Use Redis in Laravel
|
||||||
|
|
||||||
|
Open your Laravel's `.env` file and set the `REDIS_HOST` to your `Docker-IP` instead of the default `127.0.0.1` IP.
|
||||||
|
|
||||||
|
```env
|
||||||
|
REDIS_HOST=xxx.xxx.xxx.xxx
|
||||||
|
```
|
||||||
|
|
||||||
|
If you don't find the `REDIS_HOST` variable in your `.env` file. Go to the database config file `config/database.php` and replace the default `127.0.0.1` IP with your `Docker-IP` for Redis like this:
|
||||||
|
|
||||||
|
```php
|
||||||
|
'redis' => [
|
||||||
|
'cluster' => false,
|
||||||
|
'default' => [
|
||||||
|
'host' => 'xxx.xxx.xxx.xxx',
|
||||||
|
'port' => 6379,
|
||||||
|
'database' => 0,
|
||||||
|
],
|
||||||
|
],
|
||||||
|
```
|
||||||
|
|
||||||
|
To enable Redis Caching and/or for Sessions Management. Also from the `.env` file set `CACHE_DRIVER` and `SESSION_DRIVER` to `redis` instead of the default `file`.
|
||||||
|
|
||||||
|
```env
|
||||||
|
CACHE_DRIVER=redis
|
||||||
|
SESSION_DRIVER=redis
|
||||||
|
```
|
||||||
|
|
||||||
|
Finally make sure you have the `predis/predis` package `(~1.0)` installed via Composer first.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
composer require predis/predis:^1.0
|
||||||
|
```
|
||||||
|
|
||||||
|
You can manually test it with:
|
||||||
|
|
||||||
|
```php
|
||||||
|
\Cache::store('redis')->put('laradock', 'awesome', 10);
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
<a name="Use-custom-Domain"></a>
|
||||||
|
#### Use custom Domain (instead of the Docker IP)
|
||||||
|
|
||||||
|
Assuming your custom domain is `laravel.dev` and your current `Docker-IP` is `xxx.xxx.xxx.xxx`.
|
||||||
|
|
||||||
|
1 - Open your `/etc/hosts` file and map your `Docker IP` to the `laravel.dev` domain, by adding the following:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
xxx.xxx.xxx.xxx laravel.dev
|
||||||
|
```
|
||||||
|
|
||||||
|
2 - Open your Laravel's `.env` file and replace the `127.0.0.1` default values with your `{Docker-IP}`.
|
||||||
|
<br>
|
||||||
|
Example:
|
||||||
|
|
||||||
|
```env
|
||||||
|
DB_HOST=xxx.xxx.xxx.xxx
|
||||||
|
```
|
||||||
|
|
||||||
|
3 - Open your browser and visit `{http://laravel.dev}`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Optionally you can define the server name in the nginx config file, like this:
|
||||||
|
|
||||||
|
```
|
||||||
|
server_name laravel.dev;
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
#### Edit a Container (change Ports or Volumes)
|
<a name="Change-the-PHP-Version"></a>
|
||||||
|
#### Change the PHP Version
|
||||||
|
By default **PHP 7.0** is running.
|
||||||
|
<br>
|
||||||
|
To change the default PHP version:
|
||||||
|
|
||||||
|
1 - Open the `dockerfile` of the `php` folder.
|
||||||
|
|
||||||
|
2 - Change the PHP version number in the first line,
|
||||||
|
|
||||||
|
```txt
|
||||||
|
FROM php:7.0-fpm
|
||||||
|
```
|
||||||
|
|
||||||
|
Supported Versions:
|
||||||
|
|
||||||
|
- For (PHP 7.0.*) use `php:7.0-fpm`
|
||||||
|
- For (PHP 5.6.*) use `php:5.6-fpm`
|
||||||
|
- For (PHP 5.5.*) use `php:5.5-fpm`
|
||||||
|
|
||||||
|
For more details visit the [official PHP docker images](https://hub.docker.com/_/php/).
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
<a name="Add-Docker-Images"></a>
|
||||||
|
#### Add more Software's (Docker Images)
|
||||||
|
|
||||||
|
To add an image (software), just edit the `docker-compose.yml` and add your container details, to do so you need to be familiar with the [docker compose file syntax](https://docs.docker.com/compose/compose-file/).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
<a name="Edit-a-Docker-Container"></a>
|
||||||
|
#### Edit a Docker Container (change Ports or Volumes)
|
||||||
To modify a container you can simply open the `docker-compose.yml` and change everything you want.
|
To modify a container you can simply open the `docker-compose.yml` and change everything you want.
|
||||||
|
|
||||||
Example: if you want to set the MySQL port to 3333, just replace the default port with yours:
|
Example: if you want to set the MySQL port to 3333, just replace the default port with yours:
|
||||||
@ -242,25 +300,107 @@ Example: if you want to set the MySQL port to 3333, just replace the default por
|
|||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
<a name="View-the-Log-files"></a>
|
||||||
#### View the Log files
|
#### View the Log files
|
||||||
The Log files are stored in the `docker/logs` directory.
|
The Log files are stored in the `docker/logs` directory.
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
<a name="Enter-Container"></a>
|
||||||
|
#### Enter a Container (SSH into a running Container)
|
||||||
|
|
||||||
|
1 - first list the current running containers with `docker ps`
|
||||||
|
|
||||||
|
2 - enter any container with:
|
||||||
|
|
||||||
|
Example: enter the `php` container
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker exec -it php bash
|
||||||
|
```
|
||||||
|
|
||||||
|
Example: enter the `nginx` container
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker exec -it nginx bash
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
#### Edit an existing Image (change some configuration in the image)
|
<a name="AddRemove-a-Docker-Container"></a>
|
||||||
To edit an image, and take full control of it:
|
#### Add/Remove a Docker Container
|
||||||
|
To prevent a container (software) from running, open the `docker-compose.yml` file, and comment out the container section or remove it entirely.
|
||||||
|
|
||||||
1. Clone any Image from [https://github.com/LaraDock](https://github.com/LaraDock)
|
|
||||||
2. Modify the `Dockfile`
|
|
||||||
3. Run `docker build -t {your-image-name} .`
|
|
||||||
|
|
||||||
All the images are open source and hosted on the [Docker Hub](https://hub.docker.com/u/laradock/).
|
|
||||||
|
<br>
|
||||||
|
<a name="Edit-a-Docker-Image"></a>
|
||||||
|
#### Edit a Docker Image
|
||||||
|
|
||||||
|
1 - Find the `dockerfile` of the image you want to edit,
|
||||||
|
<br>
|
||||||
|
example for `php` it will be `docker/php/dockerfile`.
|
||||||
|
|
||||||
|
2 - Edit the file the way you want.
|
||||||
|
|
||||||
|
3 - Re-build the container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose build
|
||||||
|
```
|
||||||
|
|
||||||
*If you find any bug or you have and suggestion that can improve the performance of any image, please consider contributing. Thanks in advance.*
|
*If you find any bug or you have and suggestion that can improve the performance of any image, please consider contributing. Thanks in advance.*
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
<a name="Run-Docker-Virtual-Host"></a>
|
||||||
|
#### Run a Docker Virtual Host
|
||||||
|
|
||||||
|
These steps are only for **Windows & MAC** users *(Linux users don't need a virtual host)*:
|
||||||
|
|
||||||
|
1 - Run the default Host:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-machine start default
|
||||||
|
```
|
||||||
|
|
||||||
|
* If the host "default" does not exist, create one using the command below, else skip it:
|
||||||
|
|
||||||
|
* ```bash
|
||||||
|
docker-machine create -d virtualbox default
|
||||||
|
```
|
||||||
|
|
||||||
|
2 - Run this command to configure your shell:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
eval $(docker-machine env)
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
<a name="Find-Docker-IP-Address"></a>
|
||||||
|
#### Find your Docker IP Address
|
||||||
|
|
||||||
|
**On Windows & MAC:**
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-machine ip default
|
||||||
|
```
|
||||||
|
*(The default IP is 192.168.99.100)*
|
||||||
|
|
||||||
|
**On Linux:**
|
||||||
|
|
||||||
|
Your IP Address is `127.0.0.1`
|
||||||
|
|
||||||
|
> **boot2docker** users: run `boot2docker ip` *(when boot2docker is up)*.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
@ -274,6 +414,10 @@ All Docker Images can be found at [https://github.com/LaraDock](https://github.c
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### Questions?
|
||||||
|
If you have any question, send me a direct message on LaraChat, my username is `mahmoud_zalt`.
|
||||||
|
|
||||||
|
|
||||||
## Credits
|
## Credits
|
||||||
|
|
||||||
[](http://www.zalt.me)
|
[](http://www.zalt.me)
|
||||||
@ -283,3 +427,4 @@ All Docker Images can be found at [https://github.com/LaraDock](https://github.c
|
|||||||
## License
|
## License
|
||||||
|
|
||||||
[MIT License (MIT)](https://github.com/laradock/laradock/blob/master/LICENSE)
|
[MIT License (MIT)](https://github.com/laradock/laradock/blob/master/LICENSE)
|
||||||
|
[]([]())
|
5
data/Dockerfile
Normal file
5
data/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM debian:jessie
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
CMD ["true"]
|
@ -1,61 +1,65 @@
|
|||||||
# PHP + NGINX Container #----------------------------------
|
version: '2'
|
||||||
php-nginx:
|
services:
|
||||||
image: laradock/php56nginx:0.1.0
|
|
||||||
container_name: php-nginx
|
### Nginx Server Container ##################################
|
||||||
|
|
||||||
|
nginx:
|
||||||
|
build: ./nginx
|
||||||
|
container_name: nginx
|
||||||
|
volumes_from:
|
||||||
|
- php
|
||||||
|
volumes:
|
||||||
|
- ./logs/nginx/:/var/log/nginx
|
||||||
ports:
|
ports:
|
||||||
- "80:80"
|
- "80:80"
|
||||||
|
links:
|
||||||
|
- php
|
||||||
|
|
||||||
|
### PHP Container ###########################################
|
||||||
|
|
||||||
|
php:
|
||||||
|
build: ./php
|
||||||
|
container_name: php
|
||||||
volumes:
|
volumes:
|
||||||
- ./settings/nginx:/etc/nginx/sites-available
|
- ../:/var/www/laravel
|
||||||
- ../:/var/www
|
- ./logs/php/:/usr/local/var/log
|
||||||
- ./logs/nginx:/var/log/nginx
|
expose:
|
||||||
|
- "9000"
|
||||||
links:
|
links:
|
||||||
- mysql
|
- mysql
|
||||||
- redis
|
|
||||||
privileged: true
|
|
||||||
extra_hosts:
|
|
||||||
- "laravel.dev:xxx.xxx.xxx.xxx"
|
|
||||||
|
|
||||||
# MySQL Container #----------------------------------------
|
### MySQL Container #########################################
|
||||||
|
|
||||||
mysql:
|
mysql:
|
||||||
image: laradock/mysql:0.1.0
|
build: ./mysql
|
||||||
container_name: mysql
|
container_name: mysql
|
||||||
ports:
|
|
||||||
- "3306:3306"
|
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- data
|
- data
|
||||||
|
ports:
|
||||||
|
- "3306:3306"
|
||||||
environment:
|
environment:
|
||||||
MYSQL_DATABASE: homestead
|
MYSQL_DATABASE: homestead
|
||||||
MYSQL_USER: homestead
|
MYSQL_USER: homestead
|
||||||
MYSQL_PASSWORD: secret
|
MYSQL_PASSWORD: secret
|
||||||
privileged: true
|
MYSQL_ROOT_PASSWORD: root
|
||||||
|
|
||||||
|
### Redis Container #########################################
|
||||||
|
|
||||||
# Redis Container #----------------------------------------
|
|
||||||
redis:
|
redis:
|
||||||
image: laradock/redis:0.1.0
|
build: ./redis
|
||||||
container_name: redis
|
container_name: redis
|
||||||
ports:
|
|
||||||
- "6379:6379"
|
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- data
|
- data
|
||||||
volumes:
|
ports:
|
||||||
- ./logs/redis:/var/log/redis
|
- "6379:6379"
|
||||||
restart: always
|
|
||||||
privileged: true
|
### DATA Container ##########################################
|
||||||
|
|
||||||
# Data Volume Container #----------------------------------
|
|
||||||
data:
|
data:
|
||||||
image: laradock/data:0.1.0
|
build: ./data
|
||||||
container_name: data
|
container_name: data
|
||||||
volumes:
|
volumes:
|
||||||
- /var/lib/mysql
|
- /var/lib/mysql
|
||||||
- /var/lib/redis
|
- /var/lib/redis
|
||||||
|
|
||||||
# Beanstalkd Container #-----------------------------------
|
### Add more Containers below ###############################
|
||||||
# beanstalkd:
|
|
||||||
# image: laradock/beanstalkd:0.1.0
|
|
||||||
# container_name: beanstalkd
|
|
||||||
# ports:
|
|
||||||
# - "11300:11300"
|
|
||||||
# privileged: true
|
|
||||||
|
|
||||||
#----------------------------------------------------------
|
|
||||||
|
9
mysql/Dockerfile
Normal file
9
mysql/Dockerfile
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
FROM mysql:latest
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
VOLUME /var/lib/mysql
|
||||||
|
|
||||||
|
CMD ["mysqld"]
|
||||||
|
|
||||||
|
EXPOSE 3306
|
14
nginx/Dockerfile
Normal file
14
nginx/Dockerfile
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
FROM nginx:latest
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
ADD nginx.conf /etc/nginx/
|
||||||
|
ADD laravel.conf /etc/nginx/sites-available/
|
||||||
|
|
||||||
|
RUN echo "upstream php-upstream { server php:9000; }" > /etc/nginx/conf.d/upstream.conf
|
||||||
|
|
||||||
|
RUN usermod -u 1000 www-data
|
||||||
|
|
||||||
|
CMD ["nginx"]
|
||||||
|
|
||||||
|
EXPOSE 80 443
|
@ -2,18 +2,16 @@ server {
|
|||||||
listen 80 default_server;
|
listen 80 default_server;
|
||||||
listen [::]:80 default_server ipv6only=on;
|
listen [::]:80 default_server ipv6only=on;
|
||||||
|
|
||||||
root /var/www/public;
|
root /var/www/laravel/public;
|
||||||
index index.php index.html index.htm;
|
index index.php index.html index.htm;
|
||||||
|
|
||||||
server_name laravel.dev;
|
|
||||||
|
|
||||||
location / {
|
location / {
|
||||||
try_files $uri $uri/ /index.php$is_args$args;
|
try_files $uri $uri/ /index.php$is_args$args;
|
||||||
}
|
}
|
||||||
|
|
||||||
location ~ \.php$ {
|
location ~ \.php$ {
|
||||||
try_files $uri /index.php =404;
|
try_files $uri /index.php =404;
|
||||||
fastcgi_pass unix:/var/run/php5-fpm.sock;
|
fastcgi_pass php-upstream;
|
||||||
fastcgi_index index.php;
|
fastcgi_index index.php;
|
||||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||||
include fastcgi_params;
|
include fastcgi_params;
|
||||||
@ -23,3 +21,6 @@ server {
|
|||||||
deny all;
|
deny all;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
29
nginx/nginx.conf
Normal file
29
nginx/nginx.conf
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
user www-data;
|
||||||
|
worker_processes 4;
|
||||||
|
pid /run/nginx.pid;
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 2048;
|
||||||
|
multi_accept on;
|
||||||
|
use epoll;
|
||||||
|
}
|
||||||
|
|
||||||
|
http {
|
||||||
|
server_tokens off;
|
||||||
|
sendfile on;
|
||||||
|
tcp_nopush on;
|
||||||
|
tcp_nodelay on;
|
||||||
|
keepalive_timeout 15;
|
||||||
|
types_hash_max_size 2048;
|
||||||
|
include /etc/nginx/mime.types;
|
||||||
|
default_type application/octet-stream;
|
||||||
|
access_log off;
|
||||||
|
error_log off;
|
||||||
|
gzip on;
|
||||||
|
gzip_disable "msie6";
|
||||||
|
include /etc/nginx/conf.d/*.conf;
|
||||||
|
include /etc/nginx/sites-available/*;
|
||||||
|
open_file_cache max=100;
|
||||||
|
}
|
||||||
|
|
||||||
|
daemon off;
|
16
php/Dockerfile
Normal file
16
php/Dockerfile
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
FROM php:7.0-fpm
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
ADD ./laravel.ini /usr/local/etc/php/conf.d
|
||||||
|
ADD ./laravel.pool.conf /usr/local/etc/php-fpm.d/
|
||||||
|
|
||||||
|
# Install extensions using the helper script provided by the base image
|
||||||
|
RUN docker-php-ext-install \
|
||||||
|
pdo_mysql
|
||||||
|
|
||||||
|
RUN usermod -u 1000 www-data
|
||||||
|
|
||||||
|
CMD ["php-fpm"]
|
||||||
|
|
||||||
|
EXPOSE 9000
|
3
php/laravel.ini
Normal file
3
php/laravel.ini
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
date.timezone = UTC
|
||||||
|
display_errors = Off
|
||||||
|
log_errors = On
|
76
php/laravel.pool.conf
Normal file
76
php/laravel.pool.conf
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
; Unix user/group of processes
|
||||||
|
; Note: The user is mandatory. If the group is not set, the default user's group
|
||||||
|
; will be used.
|
||||||
|
user = www-data
|
||||||
|
group = www-data
|
||||||
|
|
||||||
|
; The address on which to accept FastCGI requests.
|
||||||
|
; Valid syntaxes are:
|
||||||
|
; 'ip.add.re.ss:port' - to listen on a TCP socket to a specific address on
|
||||||
|
; a specific port;
|
||||||
|
; 'port' - to listen on a TCP socket to all addresses on a
|
||||||
|
; specific port;
|
||||||
|
; '/path/to/unix/socket' - to listen on a unix socket.
|
||||||
|
; Note: This value is mandatory.
|
||||||
|
listen = 0.0.0.0:9000
|
||||||
|
|
||||||
|
; Choose how the process manager will control the number of child processes.
|
||||||
|
; Possible Values:
|
||||||
|
; static - a fixed number (pm.max_children) of child processes;
|
||||||
|
; dynamic - the number of child processes are set dynamically based on the
|
||||||
|
; following directives. With this process management, there will be
|
||||||
|
; always at least 1 children.
|
||||||
|
; pm.max_children - the maximum number of children that can
|
||||||
|
; be alive at the same time.
|
||||||
|
; pm.start_servers - the number of children created on startup.
|
||||||
|
; pm.min_spare_servers - the minimum number of children in 'idle'
|
||||||
|
; state (waiting to process). If the number
|
||||||
|
; of 'idle' processes is less than this
|
||||||
|
; number then some children will be created.
|
||||||
|
; pm.max_spare_servers - the maximum number of children in 'idle'
|
||||||
|
; state (waiting to process). If the number
|
||||||
|
; of 'idle' processes is greater than this
|
||||||
|
; number then some children will be killed.
|
||||||
|
; ondemand - no children are created at startup. Children will be forked when
|
||||||
|
; new requests will connect. The following parameter are used:
|
||||||
|
; pm.max_children - the maximum number of children that
|
||||||
|
; can be alive at the same time.
|
||||||
|
; pm.process_idle_timeout - The number of seconds after which
|
||||||
|
; an idle process will be killed.
|
||||||
|
; Note: This value is mandatory.
|
||||||
|
pm = dynamic
|
||||||
|
|
||||||
|
; The number of child processes to be created when pm is set to 'static' and the
|
||||||
|
; maximum number of child processes when pm is set to 'dynamic' or 'ondemand'.
|
||||||
|
; This value sets the limit on the number of simultaneous requests that will be
|
||||||
|
; served. Equivalent to the ApacheMaxClients directive with mpm_prefork.
|
||||||
|
; Equivalent to the PHP_FCGI_CHILDREN environment variable in the original PHP
|
||||||
|
; CGI. The below defaults are based on a server without much resources. Don't
|
||||||
|
; forget to tweak pm.* to fit your needs.
|
||||||
|
; Note: Used when pm is set to 'static', 'dynamic' or 'ondemand'
|
||||||
|
; Note: This value is mandatory.
|
||||||
|
pm.max_children = 20
|
||||||
|
|
||||||
|
; The number of child processes created on startup.
|
||||||
|
; Note: Used only when pm is set to 'dynamic'
|
||||||
|
; Default Value: min_spare_servers + (max_spare_servers - min_spare_servers) / 2
|
||||||
|
pm.start_servers = 2
|
||||||
|
|
||||||
|
; The desired minimum number of idle server processes.
|
||||||
|
; Note: Used only when pm is set to 'dynamic'
|
||||||
|
; Note: Mandatory when pm is set to 'dynamic'
|
||||||
|
pm.min_spare_servers = 1
|
||||||
|
|
||||||
|
; The desired maximum number of idle server processes.
|
||||||
|
; Note: Used only when pm is set to 'dynamic'
|
||||||
|
; Note: Mandatory when pm is set to 'dynamic'
|
||||||
|
pm.max_spare_servers = 3
|
||||||
|
|
||||||
|
;---------------------
|
||||||
|
|
||||||
|
; Make specific Docker environment variables available to PHP
|
||||||
|
env[DB_1_ENV_MYSQL_DATABASE] = $DB_1_ENV_MYSQL_DATABASE
|
||||||
|
env[DB_1_ENV_MYSQL_USER] = $DB_1_ENV_MYSQL_USER
|
||||||
|
env[DB_1_ENV_MYSQL_PASSWORD] = $DB_1_ENV_MYSQL_PASSWORD
|
||||||
|
|
||||||
|
catch_workers_output = yes
|
9
redis/Dockerfile
Normal file
9
redis/Dockerfile
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
FROM redis:latest
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
#COPY redis.conf /usr/local/etc/redis/redis.conf
|
||||||
|
|
||||||
|
CMD [ "redis-server" ]
|
||||||
|
|
||||||
|
EXPOSE 6379
|
Reference in New Issue
Block a user