Merge remote-tracking branch 'LaraDock/master'
This commit is contained in:
commit
75b1705820
116
README.md
116
README.md
@ -1,6 +1,6 @@
|
|||||||
# LaraDock
|
# LaraDock
|
||||||
|
|
||||||
[![forthebadge](http://forthebadge.com/images/badges/built-with-love.svg)](http://www.zalt.me)
|
[![forthebadge](http://forthebadge.com/images/badges/built-by-developers.svg)](http://zalt.me)
|
||||||
|
|
||||||
|
|
||||||
LaraDock helps you run your **Laravel** App on **Docker** real quick.
|
LaraDock helps you run your **Laravel** App on **Docker** real quick.
|
||||||
@ -15,6 +15,11 @@ It's like Laravel Homestead but for Docker instead of Vagrant.
|
|||||||
|
|
||||||
|
|
||||||
- [Intro](#Intro)
|
- [Intro](#Intro)
|
||||||
|
- [Features](#features)
|
||||||
|
- [What is Docker](#what-is-docker)
|
||||||
|
- [What is Laravel](#what-is-laravel)
|
||||||
|
- [Why Docker not Vagrant](#why-docker-not-vagrant)
|
||||||
|
- [LaraDock VS Homestead](#laradock-vs-homestead)
|
||||||
- [Supported Containers](#Supported-Containers)
|
- [Supported Containers](#Supported-Containers)
|
||||||
- [Requirements](#Requirements)
|
- [Requirements](#Requirements)
|
||||||
- [Installation](#Installation)
|
- [Installation](#Installation)
|
||||||
@ -47,37 +52,86 @@ 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.
|
||||||
|
|
||||||
|
|
||||||
|
<a name="features"></a>
|
||||||
|
### Features
|
||||||
|
|
||||||
|
- Easy switch between PHP versions: 7.0 - 5.6 - 5.5 - ...
|
||||||
|
- Choose your favorite database engine: MySQL - Postgres - Redis - ...
|
||||||
|
- Run your own combination of software's: PHP - NGINX - MySQL - ...
|
||||||
|
- Every software runs on a separate container: PHP - NGINX - ...
|
||||||
|
- Easy to customize any container, with simple edit to the `dockerfile`.
|
||||||
|
- All Images extends from an official base Image. (Trusted base Images).
|
||||||
|
- Pre-configured Nginx for Laravel. And very easy to update.
|
||||||
|
- Using of a Data container, to keep the Data safe and accessible at anytime.
|
||||||
|
- Easy to apply configurations inside containers.
|
||||||
|
- Clean and well structured Dockerfiles (`dockerfile`).
|
||||||
|
- Latest version of the Docker Compose file (`docker-compose`).
|
||||||
|
- Everything is visible and editable.
|
||||||
|
- Best practices everywhere.
|
||||||
|
|
||||||
|
|
||||||
|
<a name="what-is-docker"></a>
|
||||||
### What is Docker?
|
### What is Docker?
|
||||||
|
|
||||||
[Docker](https://www.docker.com) is an open-source project that automates the deployment of applications inside software containers, by providing an additional layer of abstraction and automation of [operating-system-level virtualization](https://en.wikipedia.org/wiki/Operating-system-level_virtualization) on Linux, Mac OS and Windows.
|
[Docker](https://www.docker.com) is an open-source project that automates the deployment of applications inside software containers, by providing an additional layer of abstraction and automation of [operating-system-level virtualization](https://en.wikipedia.org/wiki/Operating-system-level_virtualization) on Linux, Mac OS and Windows.
|
||||||
|
|
||||||
|
<a name="what-is-laravel"></a>
|
||||||
### What is Laravel?
|
### What is Laravel?
|
||||||
|
|
||||||
Seriously!!!
|
Seriously!!!
|
||||||
|
|
||||||
|
|
||||||
|
<a name="why-docker-not-vagrant"></a>
|
||||||
### Why Docker not Vagrant!?
|
### Why Docker not Vagrant!?
|
||||||
[Vagrant](https://www.vagrantup.com) gives you Virtual Machines in minutes while Docker gives you Virtual Containers in seconds.
|
|
||||||
|
[Vagrant](https://www.vagrantup.com) creates Virtual Machines in minutes while Docker creates Virtual Containers in seconds.
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
|
In addition to the speed, Docker gives tens of features that cannot be achieved with Vagrant.
|
||||||
|
|
||||||
|
Most importantly Docker can run on Development and on Production (same environment everywhere). While Vagrant is designed for Development only, (so you have to re-provision your server on Production every time).
|
||||||
|
|
||||||
|
|
||||||
|
<a name="laradock-vs-homestead"></a>
|
||||||
|
### LaraDock VS Homestead
|
||||||
|
|
||||||
|
LaraDock and [Homestead](https://laravel.com/docs/master/homestead) both gives you a complete virtual development environments. (Without the need to install and configure every single software on your own Operating System).
|
||||||
|
|
||||||
|
- Homestead is a tool that controls Vagrant for you (using Homestead special commands). And Vagrant manages your Virtual Machine.
|
||||||
|
|
||||||
|
- LaraDock is a tool that controls Docker for you (using Docker Compose official commands). And Docker manages you Virtual Containers.
|
||||||
|
|
||||||
|
Running a virtual Container is much faster than running a full virtual Machine.
|
||||||
|
<br>Thus **LaraDock is much faster than Homestead**.
|
||||||
|
|
||||||
<a name="Supported-Containers"></a>
|
<a name="Supported-Containers"></a>
|
||||||
## Supported Containers
|
## Supported Containers
|
||||||
|
|
||||||
- PHP
|
- PHP (7.0 - 5.6 - 5.5)
|
||||||
- NGINX
|
- NGINX
|
||||||
|
- Redis
|
||||||
- MySQL
|
- MySQL
|
||||||
- PostgreSQL
|
- PostgreSQL
|
||||||
- Redis
|
- MariaDB
|
||||||
|
- Beanstalkd
|
||||||
|
- Beanstalkd Console
|
||||||
- Data Volume
|
- Data Volume
|
||||||
|
|
||||||
|
Cannot find your container! we would love to have it as well. Consider contributing your container and adding it to this list.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="Requirements"></a>
|
<a name="Requirements"></a>
|
||||||
## Requirements
|
## Requirements
|
||||||
- Laravel ([Download](https://laravel.com/docs/master/installation))
|
|
||||||
- Docker Toolbox ([Download](https://www.docker.com/toolbox))
|
| Linux | Windows & MAC |
|
||||||
- Git ([Download](https://git-scm.com/downloads))
|
|-----------------------------------------------------------------------------------------|---------------------------------------------------------|
|
||||||
- Composer ([Download](https://getcomposer.org/download/))
|
| [Laravel](https://laravel.com/docs/master/installation) | [Laravel](https://laravel.com/docs/master/installation) |
|
||||||
|
| [Git](https://git-scm.com/downloads) | [Git](https://git-scm.com/downloads) |
|
||||||
|
| [Docker Engine](https://docs.docker.com/engine/installation/linux/ubuntulinux/#install) | [Docker Toolbox](https://www.docker.com/toolbox) |
|
||||||
|
| [Docker Compose](https://docs.docker.com/compose/install) | |
|
||||||
|
|
||||||
|
|
||||||
<a name="Installation"></a>
|
<a name="Installation"></a>
|
||||||
## Installation
|
## Installation
|
||||||
@ -88,7 +142,7 @@ Instead of providing a full Virtual Machines, like you get with Vagrant, Docker
|
|||||||
git clone https://github.com/LaraDock/laradock.git docker
|
git clone https://github.com/LaraDock/laradock.git docker
|
||||||
```
|
```
|
||||||
|
|
||||||
Instead of `git clone` you can use `git submodule add` in case you are already using Git for your Laravel project *(Recommended)*:
|
You can use `git submodule add` instead of `git clone` if you are already using Git for your Laravel project *(Recommended)*:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
git submodule add https://github.com/LaraDock/laradock.git docker
|
git submodule add https://github.com/LaraDock/laradock.git docker
|
||||||
@ -97,12 +151,15 @@ git submodule add https://github.com/LaraDock/laradock.git docker
|
|||||||
>These commands should create a `docker` folder, on the root directory of your Laravel project.
|
>These commands should create a `docker` folder, on the root directory of your Laravel project.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="Usage"></a>
|
<a name="Usage"></a>
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
>**(Windows & MAC users)** Make sure you have a running Docker Virtual Host on your machine first.
|
0 - For **Windows & MAC** users only: make sure you have a running Docker Virtual Host on your machine.
|
||||||
><br>
|
(**Linux** users don't need a Virtual Host, so skip this step).
|
||||||
>[How to run a Docker Virtual Host?](#Run-Docker-Virtual-Host)
|
<br>
|
||||||
|
[How to run a Docker Virtual Host?](#Run-Docker-Virtual-Host)
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
@ -121,7 +178,7 @@ DB_HOST=xxx.xxx.xxx.xxx
|
|||||||
> Running PHP, NGINX and MySQL:
|
> Running PHP, NGINX and MySQL:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker-compose up -d php nginx mysql
|
docker-compose up -d php nginx mysql redis
|
||||||
```
|
```
|
||||||
|
|
||||||
Note: you can choose your own combination of software's (containers), another example:
|
Note: you can choose your own combination of software's (containers), another example:
|
||||||
@ -129,10 +186,10 @@ Note: you can choose your own combination of software's (containers), another ex
|
|||||||
> Running PHP, NGINX, Postgres and Redis:
|
> Running PHP, NGINX, Postgres and Redis:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker-compose up -d php nginx postgres redis
|
docker-compose up -d php nginx beanstalkd postgres
|
||||||
```
|
```
|
||||||
|
|
||||||
Supported Containers: `php`, `nginx`, `mysql`, `postgres`, `redis`, `data`.
|
Supported Containers: `nginx`, `mysql`, `redis`, `postgres`, `mariadb`, `beanstalkd`, `beanstalkd-console`, `data`, `php`.
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
3 - Open your browser and visit your `{Docker-IP}` address (`http://xxx.xxx.xxx.xxx`).
|
3 - Open your browser and visit your `{Docker-IP}` address (`http://xxx.xxx.xxx.xxx`).
|
||||||
@ -172,10 +229,12 @@ docker-compose stop
|
|||||||
|
|
||||||
To stop single container do:
|
To stop single container do:
|
||||||
|
|
||||||
```php
|
```bash
|
||||||
docker-compose stop {container-name}
|
docker-compose stop {container-name}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Delete-all-existing-Containers"></a>
|
<a name="Delete-all-existing-Containers"></a>
|
||||||
#### Delete all existing Containers
|
#### Delete all existing Containers
|
||||||
@ -197,10 +256,10 @@ If you do any change to any `dockerfile` make sure you run this command, for the
|
|||||||
```bash
|
```bash
|
||||||
docker-compose build
|
docker-compose build
|
||||||
```
|
```
|
||||||
Optionally you can specify which container to rebuild (instead of rebuilding all the containers), example rebuilding `PHP`:
|
Optionally you can specify which container to rebuild (instead of rebuilding all the containers):
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker-compose build php
|
docker-compose build {container-name}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
@ -273,7 +332,11 @@ Supported Versions:
|
|||||||
|
|
||||||
For more details visit the [official PHP docker images](https://hub.docker.com/_/php/).
|
For more details visit the [official PHP docker images](https://hub.docker.com/_/php/).
|
||||||
|
|
||||||
|
3 - Finally rebuild the container
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose build php
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
@ -346,26 +409,20 @@ server_name laravel.dev;
|
|||||||
The Log files are stored in the `docker/logs` directory.
|
The Log files are stored in the `docker/logs` directory.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Enter-Container"></a>
|
<a name="Enter-Container"></a>
|
||||||
#### Enter a Container (SSH into a running Container)
|
#### Enter a Container (SSH into a running Container)
|
||||||
|
|
||||||
1 - first list the current running containers with `docker ps`
|
1 - first list the current running containers with `docker ps`
|
||||||
|
|
||||||
2 - enter any container with:
|
2 - enter any container using:
|
||||||
|
|
||||||
Example: enter the `php` container
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker exec -it php bash
|
docker exec -it {container-name-or-id} bash
|
||||||
```
|
```
|
||||||
|
3 - to exit a container, type `exit`.
|
||||||
Example: enter the `nginx` container
|
|
||||||
|
|
||||||
```bash
|
|
||||||
docker exec -it nginx bash
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
@ -375,6 +432,7 @@ To prevent a container (software) from running, open the `docker-compose.yml` fi
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Edit-a-Docker-Image"></a>
|
<a name="Edit-a-Docker-Image"></a>
|
||||||
#### Edit a Docker Image
|
#### Edit a Docker Image
|
||||||
|
15
beanstalkd-console/Dockerfile
Normal file
15
beanstalkd-console/Dockerfile
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
FROM php:latest
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y curl
|
||||||
|
|
||||||
|
RUN curl -sL https://github.com/ptrofimov/beanstalk_console/archive/master.tar.gz | tar xvz -C /tmp
|
||||||
|
RUN mv /tmp/beanstalk_console-master /source
|
||||||
|
|
||||||
|
RUN apt-get remove --purge -y curl && apt-get autoclean && apt-get clean
|
||||||
|
RUN rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
|
EXPOSE 2080
|
||||||
|
|
||||||
|
CMD bash -c 'BEANSTALK_SERVERS=$BEANSTALKD_PORT_11300_TCP_ADDR:11300 php -S 0.0.0.0:2080 -t /source/public'
|
16
beanstalkd/Dockerfile
Normal file
16
beanstalkd/Dockerfile
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
FROM phusion/baseimage:latest
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
ENV DEBIAN_FRONTEND noninteractive
|
||||||
|
ENV PATH /usr/local/rvm/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y beanstalkd
|
||||||
|
RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
|
VOLUME /var/lib/beanstalkd/data
|
||||||
|
|
||||||
|
EXPOSE 11300
|
||||||
|
|
||||||
|
CMD ["/usr/bin/beanstalkd"]
|
@ -1,11 +1,11 @@
|
|||||||
version: '2'
|
version: '2'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
|
|
||||||
### Nginx Server Container ##################################
|
### Nginx Server Container ##################################
|
||||||
|
|
||||||
nginx:
|
nginx:
|
||||||
build: ./nginx
|
build: ./nginx
|
||||||
container_name: nginx
|
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- php
|
- php
|
||||||
volumes:
|
volumes:
|
||||||
@ -19,7 +19,6 @@ services:
|
|||||||
|
|
||||||
php:
|
php:
|
||||||
build: ./php
|
build: ./php
|
||||||
container_name: php
|
|
||||||
volumes:
|
volumes:
|
||||||
- ../:/var/www/laravel
|
- ../:/var/www/laravel
|
||||||
- ./logs/php/:/usr/local/var/log
|
- ./logs/php/:/usr/local/var/log
|
||||||
@ -30,17 +29,16 @@ services:
|
|||||||
|
|
||||||
data:
|
data:
|
||||||
build: ./data
|
build: ./data
|
||||||
container_name: data
|
|
||||||
volumes:
|
volumes:
|
||||||
- /var/lib/mysql
|
- /var/lib/mysql
|
||||||
- /var/lib/postgresql/data
|
- /var/lib/postgres
|
||||||
|
- /var/lib/mariadb
|
||||||
- /var/lib/redis
|
- /var/lib/redis
|
||||||
|
|
||||||
### MySQL Container #########################################
|
### MySQL Container #########################################
|
||||||
|
|
||||||
mysql:
|
mysql:
|
||||||
build: ./mysql
|
build: ./mysql
|
||||||
container_name: mysql
|
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- data
|
- data
|
||||||
ports:
|
ports:
|
||||||
@ -57,7 +55,6 @@ services:
|
|||||||
|
|
||||||
postgres:
|
postgres:
|
||||||
build: ./postgres
|
build: ./postgres
|
||||||
container_name: postgres
|
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- data
|
- data
|
||||||
ports:
|
ports:
|
||||||
@ -69,14 +66,46 @@ services:
|
|||||||
links:
|
links:
|
||||||
- php
|
- php
|
||||||
|
|
||||||
|
### MariaDB Container #######################################
|
||||||
|
|
||||||
|
mariadb:
|
||||||
|
build: ./mariadb
|
||||||
|
volumes_from:
|
||||||
|
- data
|
||||||
|
ports:
|
||||||
|
- "3306:3306"
|
||||||
|
environment:
|
||||||
|
MYSQL_DATABASE: homestead
|
||||||
|
MYSQL_USER: homestead
|
||||||
|
MYSQL_PASSWORD: secret
|
||||||
|
MYSQL_ROOT_PASSWORD: root
|
||||||
|
links:
|
||||||
|
- php
|
||||||
|
|
||||||
### Redis Container #########################################
|
### Redis Container #########################################
|
||||||
|
|
||||||
redis:
|
redis:
|
||||||
build: ./redis
|
build: ./redis
|
||||||
container_name: redis
|
|
||||||
volumes_from:
|
volumes_from:
|
||||||
- data
|
- data
|
||||||
ports:
|
ports:
|
||||||
- "6379:6379"
|
- "6379:6379"
|
||||||
|
|
||||||
|
### Beanstalkd Container ####################################
|
||||||
|
|
||||||
|
beanstalkd:
|
||||||
|
build: ./beanstalkd
|
||||||
|
ports:
|
||||||
|
- "11300:11300"
|
||||||
|
privileged: true
|
||||||
|
|
||||||
|
### Beanstalkd-Console Container ############################
|
||||||
|
|
||||||
|
beanstalkd-console:
|
||||||
|
build: ./beanstalkd-console
|
||||||
|
ports:
|
||||||
|
- "2080:2080"
|
||||||
|
links:
|
||||||
|
- beanstalkd
|
||||||
|
|
||||||
### Add more Containers below ###############################
|
### Add more Containers below ###############################
|
||||||
|
9
mariadb/Dockerfile
Normal file
9
mariadb/Dockerfile
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
FROM mariadb:latest
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
VOLUME /var/lib/mariadb
|
||||||
|
|
||||||
|
CMD ["mysqld"]
|
||||||
|
|
||||||
|
EXPOSE 3306
|
@ -2,7 +2,7 @@ FROM postgres:latest
|
|||||||
|
|
||||||
MAINTAINER Ben M <git@bmagg.com>
|
MAINTAINER Ben M <git@bmagg.com>
|
||||||
|
|
||||||
VOLUME /var/lib/postgresql/data
|
VOLUME /var/lib/postgres
|
||||||
|
|
||||||
CMD ["postgres"]
|
CMD ["postgres"]
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user