Compare commits
22 Commits
Author | SHA1 | Date | |
---|---|---|---|
adaaa25f47 | |||
11a13a0c33 | |||
c642560993 | |||
ea9f5c635f | |||
fd4253afb6 | |||
73310e45e8 | |||
7f91fc9798 | |||
a8a7685a40 | |||
06c4c19a6f | |||
8bff7656f6 | |||
5c9eb97db5 | |||
588819ab6d | |||
170b63a3ba | |||
19813e48c3 | |||
be7b8ee056 | |||
01a056dd25 | |||
70e1b0fe41 | |||
0959b25c05 | |||
1d8336a9e1 | |||
f0e2d83618 | |||
7f1deb0342 | |||
703887a2a6 |
263
README.md
263
README.md
@ -21,6 +21,7 @@ It's like Laravel Homestead but for Docker instead of Vagrant.
|
|||||||
- [What is Laravel](#what-is-laravel)
|
- [What is Laravel](#what-is-laravel)
|
||||||
- [Why Docker not Vagrant](#why-docker-not-vagrant)
|
- [Why Docker not Vagrant](#why-docker-not-vagrant)
|
||||||
- [LaraDock VS Homestead](#laradock-vs-homestead)
|
- [LaraDock VS Homestead](#laradock-vs-homestead)
|
||||||
|
- [Demo Video](#Demo)
|
||||||
- [Requirements](#Requirements)
|
- [Requirements](#Requirements)
|
||||||
- [Installation](#Installation)
|
- [Installation](#Installation)
|
||||||
- [Usage](#Usage)
|
- [Usage](#Usage)
|
||||||
@ -36,6 +37,7 @@ It's like Laravel Homestead but for Docker instead of Vagrant.
|
|||||||
- [Add more Software's (Docker Images)](#Add-Docker-Images)
|
- [Add more Software's (Docker Images)](#Add-Docker-Images)
|
||||||
- [View the Log files](#View-the-Log-files)
|
- [View the Log files](#View-the-Log-files)
|
||||||
- [Laravel](#Laravel):
|
- [Laravel](#Laravel):
|
||||||
|
- [Install Laravel from a Docker Container](#Install-Laravel)
|
||||||
- [Run Artisan Commands](#Run-Artisan-Commands)
|
- [Run Artisan Commands](#Run-Artisan-Commands)
|
||||||
- [Use Redis](#Use-Redis)
|
- [Use Redis](#Use-Redis)
|
||||||
- [PHP](#PHP)
|
- [PHP](#PHP)
|
||||||
@ -46,7 +48,7 @@ It's like Laravel Homestead but for Docker instead of Vagrant.
|
|||||||
- [Run a Docker Virtual Host](#Run-Docker-Virtual-Host)
|
- [Run a Docker Virtual Host](#Run-Docker-Virtual-Host)
|
||||||
- [Find your Docker IP Address](#Find-Docker-IP-Address)
|
- [Find your Docker IP Address](#Find-Docker-IP-Address)
|
||||||
- [Use custom Domain](#Use-custom-Domain)
|
- [Use custom Domain](#Use-custom-Domain)
|
||||||
|
- [Help & Questions](#Help)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -57,10 +59,10 @@ 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.
|
||||||
|
|
||||||
|
|
||||||
**Usage Overview:** Run `NGINX` and `MySQL`.
|
**Usage Overview:** Run `NGINX`, `MySQL` and `Redis`.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
docker-compose up nginx mysql
|
docker-compose up nginx mysql redis
|
||||||
```
|
```
|
||||||
|
|
||||||
<a name="features"></a>
|
<a name="features"></a>
|
||||||
@ -88,12 +90,13 @@ docker-compose up nginx mysql
|
|||||||
- MySQL
|
- MySQL
|
||||||
- PostgreSQL
|
- PostgreSQL
|
||||||
- MariaDB
|
- MariaDB
|
||||||
|
- Neo4j
|
||||||
- Redis
|
- Redis
|
||||||
- Memcached
|
- Memcached
|
||||||
- Beanstalkd
|
- Beanstalkd
|
||||||
- Beanstalkd Console
|
- Beanstalkd Console
|
||||||
- Workspace (includes: Composer, PHP7-CLI, Laravel Installer, Git, Vim, Nano and cURL)
|
- Workspace (contains: Composer, PHP7-CLI, Laravel Installer, Git, Node, Gulp, Bower, SQLite, Vim, Nano and cURL)
|
||||||
- Data Volume *(Databases Data Container)*
|
- Data *(Databases Data Container)*
|
||||||
- Application *(Application Code Container)*
|
- Application *(Application Code Container)*
|
||||||
|
|
||||||
|
|
||||||
@ -151,117 +154,103 @@ Running a virtual Container is much faster than running a full virtual Machine.
|
|||||||
| [Docker Compose](https://docs.docker.com/compose/install) | |
|
| [Docker Compose](https://docs.docker.com/compose/install) | |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="Demo"></a>
|
||||||
|
## Demo Video
|
||||||
|
|
||||||
|
What's better than a [**Demo Video**](https://www.youtube.com/watch?v=-DamFMczwDA) :)
|
||||||
|
|
||||||
<a name="Installation"></a>
|
<a name="Installation"></a>
|
||||||
## Installation
|
## Installation
|
||||||
|
|
||||||
#### A - In existing Laravel Projects:
|
|
||||||
|
|
||||||
1 - Clone the `LaraDock` repository, inside your `Laravel` project root direcotry:
|
1 - Clone the `LaraDock` repository.
|
||||||
|
|
||||||
|
**A)** If you already have a Laravel project, clone this repository on your `Laravel` root direcotry:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
git submodule add https://github.com/LaraDock/laradock.git
|
git submodule add https://github.com/LaraDock/laradock.git
|
||||||
```
|
```
|
||||||
|
>If you are not already using Git for your Laravel project, you can use `git clone` instead of `git submodule`.
|
||||||
|
|
||||||
2 - That's it, jump to the Usage section now.
|
**B)** If you don't have a Laravel project, and you want to install Laravel from Docker, clone this repo anywhere on your machine:
|
||||||
|
|
||||||
*If you are not already using Git for your Laravel project, you can use `git clone` instead of `git submodule`.*
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
|
||||||
#### B - From scratch (Install LaraDock and Laravel):
|
|
||||||
|
|
||||||
*If you don't have any Laravel project yet, and you want to start your Laravel project with Docker.*
|
|
||||||
|
|
||||||
1 - Clone the `LaraDock` repository anywhere on your machine:
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
git clone https://github.com/LaraDock/laradock.git
|
git clone https://github.com/LaraDock/laradock.git
|
||||||
```
|
```
|
||||||
|
|
||||||
2 - Go to the Uage section below and do the steps 1 and 3 then come back here.
|
|
||||||
|
|
||||||
3 - Enter the Workspace container. (assuming you have the Workspace container running):
|
|
||||||
|
|
||||||
```bash
|
|
||||||
docker exec -it {Workspace-Container-Name} bash
|
|
||||||
```
|
|
||||||
Replace `{Workspace-Container-Name}` with your Workspace container name. To get the name type `docker-compose ps` and copy it.
|
|
||||||
|
|
||||||
4 - Install Laravel anyway you like.
|
|
||||||
|
|
||||||
Example using the Laravel Installer:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
laravel new my-cool-app
|
|
||||||
```
|
|
||||||
For more about this check out this [link](https://laravel.com/docs/master#installing-laravel).
|
|
||||||
|
|
||||||
5 - Edit `docker-compose.yml` to Map the new application path:
|
|
||||||
|
|
||||||
By default LaraDock assumes the Laravel application is living in the parent directory of the laradock folder.
|
|
||||||
|
|
||||||
Since the new Laravel application is in the `my-cool-app` folder, we should replace `../:/var/www/laravel` with `../my-cool-app/:/var/www/laravel`, as follow:
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
application:
|
|
||||||
build: ./application
|
|
||||||
volumes:
|
|
||||||
- ../my-cool-app/:/var/www/laravel
|
|
||||||
```
|
|
||||||
6 - finally go to the Usage section below again and do steps 2 and 4.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="Usage"></a>
|
<a name="Usage"></a>
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
1 - For **Windows & MAC** users only: make sure you have a running Docker Virtual Host on your machine.
|
|
||||||
|
1 - For **Windows & MAC** users only: If you are not using the native Docker-Engine `Beta`, make sure you have a running Docker Virtual Host on your machine.
|
||||||
(**Linux** users don't need a Virtual Host, so skip this step).
|
(**Linux** users don't need a Virtual Host, so skip this step).
|
||||||
<br>
|
|
||||||
[How to run a Docker Virtual Host?](#Run-Docker-Virtual-Host)
|
[How to run a Docker Virtual Host?](#Run-Docker-Virtual-Host)
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
2 - Open your Laravel's `.env` file and set the `DB_HOST` to your `{Docker-IP}`:
|
2 - Run the Containers, (you can select the containers that you wish to run)
|
||||||
|
<br>
|
||||||
|
*Make sure you are in the `laradock` folder before running the `docker-compose` command.*
|
||||||
|
|
||||||
|
**Example:** Running NGINX and MySQL:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose up -d nginx mysql
|
||||||
|
```
|
||||||
|
|
||||||
|
*Note: the PHP-FPM, Workspace, Application and Data Containers will automatically run.*
|
||||||
|
|
||||||
|
|
||||||
|
Supported Containers: `nginx`, `mysql`, `redis`, `postgres`, `mariadb`, `neo4j`, `memcached`, `beanstalkd`, `beanstalkd-console`, `workspace`, `data`, `php-fpm`, `application`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
3 - Enter the Workspace container, to execute commands like (Artisan, Composer, PHPUnit, Gulp, ...).
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker exec -it {Workspace-Container-Name} bash
|
||||||
|
```
|
||||||
|
Replace `{Workspace-Container-Name}` with your Workspace container name.
|
||||||
|
<br>
|
||||||
|
To find the containers names type `docker-compose ps`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
|
4 - Edit the Laravel configurations.
|
||||||
|
|
||||||
|
If you don't have a Laravel project installed yet, see [How to Install Laravel in a Docker Container](#Install-Laravel).
|
||||||
|
|
||||||
|
Open your Laravel's `.env` file and set the `DB_HOST` to your `{Docker-IP}`:
|
||||||
|
|
||||||
```env
|
```env
|
||||||
DB_HOST=xxx.xxx.xxx.xxx
|
DB_HOST=xxx.xxx.xxx.xxx
|
||||||
```
|
```
|
||||||
[How to find my Docker IP Address?](#Find-Docker-IP-Address)
|
[How to find my Docker IP Address?](#Find-Docker-IP-Address)
|
||||||
|
|
||||||
<br>
|
|
||||||
3 - Run the Containers, (you can select the software's (containers) that you wish to run)
|
|
||||||
<br>
|
|
||||||
*Make sure you are in the `laradock` folder before running the `docker-compose` command.*
|
|
||||||
|
|
||||||
**Example:** Running NGINX, MySQL, Redis and the Workspace:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
docker-compose up -d nginx mysql redis workspace
|
|
||||||
```
|
|
||||||
*Note: the PHP-FPM, Application and Data Containers will automatically run.*
|
|
||||||
|
|
||||||
|
|
||||||
Supported Containers: `workspace`, `nginx`, `mysql`, `redis`, `postgres`, `mariadb`, `memcached`, `beanstalkd`, `beanstalkd-console`, `data`, `php-fpm`, `application`.
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
4 - Open your browser and visit your `{Docker-IP}` address (`http://xxx.xxx.xxx.xxx`).
|
5 - Open your browser and visit your `{Docker-IP}` address (`http://xxx.xxx.xxx.xxx`).
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
**Debugging**: in case you faced an error here, run this command from the Laravel root directory:
|
**Debugging**: in case you faced an error here, run this command from the Laravel root directory:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
sudo chmod -R 777 storage && sudo chmod -R 777 bootstrap/cache
|
sudo chmod -R 777 storage bootstrap/cache
|
||||||
```
|
```
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
If you have any problem, or need a special support. Feel free to contact me, more details in the [Help & Questions](#Help) secion.
|
||||||
|
|
||||||
[Follow @Mahmoud_Zalt](https://twitter.com/Mahmoud_Zalt)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
@ -271,12 +260,12 @@ sudo chmod -R 777 storage && sudo chmod -R 777 bootstrap/cache
|
|||||||
|
|
||||||
|
|
||||||
<a name="Docker"></a>
|
<a name="Docker"></a>
|
||||||
### Docker
|
### [Docker]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="List-current-running-Containers"></a>
|
<a name="List-current-running-Containers"></a>
|
||||||
#### List current running Containers
|
### List current running Containers
|
||||||
```bash
|
```bash
|
||||||
docker ps
|
docker ps
|
||||||
```
|
```
|
||||||
@ -292,7 +281,7 @@ docker-compose ps
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Close-all-running-Containers"></a>
|
<a name="Close-all-running-Containers"></a>
|
||||||
#### Close all running Containers
|
### Close all running Containers
|
||||||
```bash
|
```bash
|
||||||
docker-compose stop
|
docker-compose stop
|
||||||
```
|
```
|
||||||
@ -310,7 +299,7 @@ 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
|
||||||
```bash
|
```bash
|
||||||
docker-compose down
|
docker-compose down
|
||||||
```
|
```
|
||||||
@ -325,7 +314,7 @@ docker-compose down
|
|||||||
|
|
||||||
<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`
|
||||||
|
|
||||||
@ -344,7 +333,7 @@ docker exec -it {container-name} bash
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Edit-Container"></a>
|
<a name="Edit-Container"></a>
|
||||||
#### Edit default container configuration
|
### Edit default container configuration
|
||||||
Open the `docker-compose.yml` and change anything you want.
|
Open the `docker-compose.yml` and change anything you want.
|
||||||
|
|
||||||
Examples:
|
Examples:
|
||||||
@ -372,7 +361,7 @@ Change Redis defaut port to 1111:
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Edit-a-Docker-Image"></a>
|
<a name="Edit-a-Docker-Image"></a>
|
||||||
#### Edit a Docker Image
|
### Edit a Docker Image
|
||||||
|
|
||||||
1 - Find the `dockerfile` of the image you want to edit,
|
1 - Find the `dockerfile` of the image you want to edit,
|
||||||
<br>
|
<br>
|
||||||
@ -399,7 +388,7 @@ docker-compose build mysql
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Build-Re-build-Containers"></a>
|
<a name="Build-Re-build-Containers"></a>
|
||||||
#### Build/Re-build Containers
|
### Build/Re-build Containers
|
||||||
|
|
||||||
If you do any change to any `dockerfile` make sure you run this command, for the changes to take effect:
|
If you do any change to any `dockerfile` make sure you run this command, for the changes to take effect:
|
||||||
|
|
||||||
@ -419,7 +408,7 @@ docker-compose build {container-name}
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Add-Docker-Images"></a>
|
<a name="Add-Docker-Images"></a>
|
||||||
#### Add more Software's (Docker Images)
|
### 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/).
|
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/).
|
||||||
|
|
||||||
@ -433,7 +422,7 @@ To add an image (software), just edit the `docker-compose.yml` and add your cont
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="View-the-Log-files"></a>
|
<a name="View-the-Log-files"></a>
|
||||||
#### View the Log files
|
### View the Log files
|
||||||
The Nginx Log file is stored in the `logs/nginx` directory.
|
The Nginx Log file is stored in the `logs/nginx` directory.
|
||||||
|
|
||||||
However to view the logs of all the other containers (MySQL, PHP-FPM,...) you can run this:
|
However to view the logs of all the other containers (MySQL, PHP-FPM,...) you can run this:
|
||||||
@ -448,13 +437,52 @@ docker logs {container-name}
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Laravel"></a>
|
<a name="Laravel"></a>
|
||||||
### Laravel
|
### [Laravel]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="Install-Laravel"></a>
|
||||||
|
### Install Laravel from a Docker Container
|
||||||
|
|
||||||
|
1 - First you need to enter the Workspace Container.
|
||||||
|
|
||||||
|
2 - Install Laravel.
|
||||||
|
|
||||||
|
Example using Composer
|
||||||
|
|
||||||
|
```bash
|
||||||
|
composer create-project laravel/laravel my-cool-app "5.2.*"
|
||||||
|
```
|
||||||
|
|
||||||
|
> We recommand using `composer create-project` instead of the Laravel installer, to install Laravel.
|
||||||
|
|
||||||
|
For more about the Laravel installation click [here](https://laravel.com/docs/master#installing-laravel).
|
||||||
|
|
||||||
|
|
||||||
|
3 - Edit `docker-compose.yml` to Map the new application path:
|
||||||
|
|
||||||
|
By default LaraDock assumes the Laravel application is living in the parent directory of the laradock folder.
|
||||||
|
|
||||||
|
Since the new Laravel application is in the `my-cool-app` folder, we need to replace `../:/var/www/laravel` with `../my-cool-app/:/var/www/laravel`, as follow:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
application:
|
||||||
|
build: ./application
|
||||||
|
volumes:
|
||||||
|
- ../my-cool-app/:/var/www/laravel
|
||||||
|
```
|
||||||
|
4 - Go to that folder and start working..
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd my-cool-app
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<br>
|
||||||
<a name="Run-Artisan-Commands"></a>
|
<a name="Run-Artisan-Commands"></a>
|
||||||
#### Run Artisan Commands
|
### Run Artisan Commands
|
||||||
|
|
||||||
You can run artisan commands and many other Terminal commands from the Workspace container.
|
You can run artisan commands and many other Terminal commands from the Workspace container.
|
||||||
|
|
||||||
@ -500,7 +528,7 @@ laravel new blog
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Use-Redis"></a>
|
<a name="Use-Redis"></a>
|
||||||
#### Use Redis
|
### Use Redis
|
||||||
|
|
||||||
1 - First make sure you run the Redis Container with the `docker-compose` command.
|
1 - First make sure you run the Redis Container with the `docker-compose` command.
|
||||||
|
|
||||||
@ -553,7 +581,7 @@ composer require predis/predis:^1.0
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="PHP"></a>
|
<a name="PHP"></a>
|
||||||
### PHP
|
### [PHP]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -561,7 +589,7 @@ composer require predis/predis:^1.0
|
|||||||
|
|
||||||
|
|
||||||
<a name="Install-PHP-Extensions"></a>
|
<a name="Install-PHP-Extensions"></a>
|
||||||
#### Install PHP Extensions
|
### Install PHP Extensions
|
||||||
|
|
||||||
Before installing PHP extensions, you have to decide whether you need for the `FPM` or `CLI` because each lives on a different container, if you need it for both you have to edit both containers.
|
Before installing PHP extensions, you have to decide whether you need for the `FPM` or `CLI` because each lives on a different container, if you need it for both you have to edit both containers.
|
||||||
|
|
||||||
@ -579,7 +607,7 @@ The PHP-CLI extensions should be installed in `workspace/Dockerfile`.
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Change-the-PHP-FPM-Version"></a>
|
<a name="Change-the-PHP-FPM-Version"></a>
|
||||||
#### Change the PHP-FPM Version
|
### Change the PHP-FPM Version
|
||||||
By default **PHP-FPM 7.0** is running.
|
By default **PHP-FPM 7.0** is running.
|
||||||
|
|
||||||
>The PHP-FPM is responsible of serving your application code, you don't have to change the PHP-CLI version if you are planing to run your application on different PHP-FPM version.
|
>The PHP-FPM is responsible of serving your application code, you don't have to change the PHP-CLI version if you are planing to run your application on different PHP-FPM version.
|
||||||
@ -626,7 +654,7 @@ For more details about the PHP base image, visit the [official PHP docker images
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Change-the-PHP-CLI-Version"></a>
|
<a name="Change-the-PHP-CLI-Version"></a>
|
||||||
#### Change the PHP-CLI Version
|
### Change the PHP-CLI Version
|
||||||
By default **PHP-CLI 7.0** is running.
|
By default **PHP-CLI 7.0** is running.
|
||||||
|
|
||||||
>Note: it's not very essential to edit the PHP-CLI verion. The PHP-CLI is only used for the Artisan Commands & Composer. It doesn't serve your Application code, this is the PHP-FPM job.
|
>Note: it's not very essential to edit the PHP-CLI verion. The PHP-CLI is only used for the Artisan Commands & Composer. It doesn't serve your Application code, this is the PHP-FPM job.
|
||||||
@ -647,14 +675,14 @@ Right now you have to manually edit the `Dockerfile` or create a new one like it
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Misc"></a>
|
<a name="Misc"></a>
|
||||||
### Misc
|
### [Misc]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<a name="Run-Docker-Virtual-Host"></a>
|
<a name="Run-Docker-Virtual-Host"></a>
|
||||||
#### Run a Docker Virtual Host
|
### Run a Docker Virtual Host
|
||||||
|
|
||||||
These steps are only for **Windows & MAC** users *(Linux users don't need a virtual host)*:
|
These steps are only for **Windows & MAC** users *(Linux users don't need a virtual host)*:
|
||||||
|
|
||||||
@ -684,21 +712,38 @@ eval $(docker-machine env)
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Find-Docker-IP-Address"></a>
|
<a name="Find-Docker-IP-Address"></a>
|
||||||
#### Find your Docker IP Address
|
### Find your Docker IP Address
|
||||||
|
|
||||||
**On Windows & MAC:**
|
**On Windows & MAC:**
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker-machine ip default
|
docker-machine ip default
|
||||||
```
|
```
|
||||||
|
If your Host name is different then `default`, you have to specify it (`docker-machine ip my-host`).
|
||||||
|
|
||||||
*(The default IP is 192.168.99.100)*
|
*(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)*.
|
> **boot2docker** users: run `boot2docker ip` *(when boot2docker is up)*.
|
||||||
|
|
||||||
|
<br>
|
||||||
|
**On Linux:**
|
||||||
|
|
||||||
|
1 - Run `ifconfig` in the terminal.
|
||||||
|
|
||||||
|
2 - In the result search for `docker0`, your IP address will be next to `inet addr`.
|
||||||
|
|
||||||
|
Example: (In this example your IP address is `172.17.0.1`).
|
||||||
|
|
||||||
|
```shell
|
||||||
|
docker0 Link encap:Ethernet HWaddr 02:42:41:2d:c4:24
|
||||||
|
inet addr:172.17.0.1 Bcast:0.0.0.0 Mask:255.255.0.0
|
||||||
|
UP BROADCAST MULTICAST MTU:1500 Metric:1
|
||||||
|
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
|
||||||
|
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
|
||||||
|
collisions:0 txqueuelen:0
|
||||||
|
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
|
||||||
|
```
|
||||||
|
>If you have an easier way to do it, share it with us.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -707,7 +752,7 @@ Your IP Address is `127.0.0.1`
|
|||||||
|
|
||||||
<br>
|
<br>
|
||||||
<a name="Use-custom-Domain"></a>
|
<a name="Use-custom-Domain"></a>
|
||||||
#### Use custom Domain (instead of the Docker IP)
|
### 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`.
|
Assuming your custom domain is `laravel.dev` and your current `Docker-IP` is `xxx.xxx.xxx.xxx`.
|
||||||
|
|
||||||
@ -747,27 +792,33 @@ server_name laravel.dev;
|
|||||||
<br>
|
<br>
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
This little project was built by one man who has a full time job and many responsibilities, so if you like this project and you find that it needs a bug fix or support for new software or upgrade for the current containers, or anything else.. Do not hesitate to contribute, you are more than welcome :)
|
This little project was built by one man who has a full time job and many responsibilities, so if you like this project and you find that it needs a bug fix or support for new software or upgrade any container, or anything else.. Do not hesitate to contribute, you are more than welcome :)
|
||||||
|
|
||||||
All Docker Images can be found at [https://github.com/LaraDock](https://github.com/LaraDock)
|
|
||||||
|
|
||||||
## Support
|
## Support
|
||||||
|
|
||||||
[Issues](https://github.com/laradock/laradock/issues) on Github.
|
To suggest a features or report a bug, open a new [Issue](https://github.com/laradock/laradock/issues).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### Questions?
|
<a name="Help"></a>
|
||||||
If you have any question, send me a direct message on LaraChat, my username is `mahmoud_zalt`.
|
## Help & Questions
|
||||||
|
|
||||||
|
If you need help with anything related to this project, shedule a live call with me on [Codementor](https://www.codementor.io/mahmoudz), I'd love to help.
|
||||||
|
|
||||||
|
If you have a short question, send me a direct message on LaraChat, my username is `mahmoud_zalt`. Or send me an email on `mahmoud@zalt.me`.
|
||||||
|
|
||||||
|
|
||||||
## Credits
|
## Credits
|
||||||
|
|
||||||
[](http://www.zalt.me)
|
[](http://www.zalt.me)
|
||||||
|
|
||||||
|
Twitter: [@Mahmoud_Zalt](https://twitter.com/Mahmoud_Zalt)
|
||||||
|
<br>
|
||||||
|
Website: [http://zalt.me](http://zalt.me)
|
||||||
|
<br>
|
||||||
|
Email: `mahmoud@zalt.me`
|
||||||
|
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
[MIT License (MIT)](https://github.com/laradock/laradock/blob/master/LICENSE)
|
[MIT License](https://github.com/laradock/laradock/blob/master/LICENSE) (MIT)
|
||||||
[]([]())
|
|
||||||
|
@ -12,6 +12,8 @@ services:
|
|||||||
- application
|
- application
|
||||||
expose:
|
expose:
|
||||||
- "9000"
|
- "9000"
|
||||||
|
links:
|
||||||
|
- workspace
|
||||||
|
|
||||||
### Laravel Application Code Container ######################
|
### Laravel Application Code Container ######################
|
||||||
|
|
||||||
@ -30,6 +32,7 @@ services:
|
|||||||
- /var/lib/mariadb
|
- /var/lib/mariadb
|
||||||
- /var/lib/redis
|
- /var/lib/redis
|
||||||
- /var/lib/memcached
|
- /var/lib/memcached
|
||||||
|
- /var/lib/neo4j/data
|
||||||
|
|
||||||
### Nginx Server Container ##################################
|
### Nginx Server Container ##################################
|
||||||
|
|
||||||
@ -58,8 +61,6 @@ services:
|
|||||||
MYSQL_USER: homestead
|
MYSQL_USER: homestead
|
||||||
MYSQL_PASSWORD: secret
|
MYSQL_PASSWORD: secret
|
||||||
MYSQL_ROOT_PASSWORD: root
|
MYSQL_ROOT_PASSWORD: root
|
||||||
links:
|
|
||||||
- php-fpm
|
|
||||||
|
|
||||||
### PostgreSQL Container ####################################
|
### PostgreSQL Container ####################################
|
||||||
|
|
||||||
@ -73,8 +74,6 @@ services:
|
|||||||
POSTGRES_DB: homestead
|
POSTGRES_DB: homestead
|
||||||
POSTGRES_USER: homestead
|
POSTGRES_USER: homestead
|
||||||
POSTGRES_PASSWORD: secret
|
POSTGRES_PASSWORD: secret
|
||||||
links:
|
|
||||||
- php-fpm
|
|
||||||
|
|
||||||
### MariaDB Container #######################################
|
### MariaDB Container #######################################
|
||||||
|
|
||||||
@ -89,8 +88,18 @@ services:
|
|||||||
MYSQL_USER: homestead
|
MYSQL_USER: homestead
|
||||||
MYSQL_PASSWORD: secret
|
MYSQL_PASSWORD: secret
|
||||||
MYSQL_ROOT_PASSWORD: root
|
MYSQL_ROOT_PASSWORD: root
|
||||||
links:
|
|
||||||
- php-fpm
|
### Neo4j Container #########################################
|
||||||
|
|
||||||
|
neo4j:
|
||||||
|
build: ./neo4j
|
||||||
|
ports:
|
||||||
|
- "7474:7474"
|
||||||
|
- "1337:1337"
|
||||||
|
environment:
|
||||||
|
- NEO4J_AUTH=homestead:secret
|
||||||
|
volumes_from:
|
||||||
|
- data
|
||||||
|
|
||||||
### Redis Container #########################################
|
### Redis Container #########################################
|
||||||
|
|
||||||
@ -100,8 +109,6 @@ services:
|
|||||||
- data
|
- data
|
||||||
ports:
|
ports:
|
||||||
- "6379:6379"
|
- "6379:6379"
|
||||||
links:
|
|
||||||
- php-fpm
|
|
||||||
|
|
||||||
### Memcached Container #####################################
|
### Memcached Container #####################################
|
||||||
|
|
||||||
|
7
neo4j/Dockerfile
Normal file
7
neo4j/Dockerfile
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
FROM tpires/neo4j
|
||||||
|
|
||||||
|
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
||||||
|
|
||||||
|
VOLUME /var/lib/neo4j/data
|
||||||
|
|
||||||
|
EXPOSE 7474 1337
|
@ -17,8 +17,8 @@ http {
|
|||||||
types_hash_max_size 2048;
|
types_hash_max_size 2048;
|
||||||
include /etc/nginx/mime.types;
|
include /etc/nginx/mime.types;
|
||||||
default_type application/octet-stream;
|
default_type application/octet-stream;
|
||||||
access_log off;
|
access_log on;
|
||||||
error_log off;
|
error_log on;
|
||||||
gzip on;
|
gzip on;
|
||||||
gzip_disable "msie6";
|
gzip_disable "msie6";
|
||||||
include /etc/nginx/conf.d/*.conf;
|
include /etc/nginx/conf.d/*.conf;
|
||||||
|
@ -4,6 +4,8 @@ MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
|
|||||||
|
|
||||||
#COPY redis.conf /usr/local/etc/redis/redis.conf
|
#COPY redis.conf /usr/local/etc/redis/redis.conf
|
||||||
|
|
||||||
|
VOLUME /var/lib/redis
|
||||||
|
|
||||||
CMD [ "redis-server" ]
|
CMD [ "redis-server" ]
|
||||||
|
|
||||||
EXPOSE 6379
|
EXPOSE 6379
|
||||||
|
@ -11,14 +11,16 @@ ENV LC_CTYPE=UTF-8
|
|||||||
ENV LANG=en_US.UTF-8
|
ENV LANG=en_US.UTF-8
|
||||||
ENV TERM xterm
|
ENV TERM xterm
|
||||||
|
|
||||||
# Install "software-properties-common" (for add-apt-repository) and add the "PHP 7" ppa
|
# Install "software-properties-common" (for the "add-apt-repository")
|
||||||
RUN apt-get update \
|
RUN apt-get update && apt-get install -y \
|
||||||
&& apt-get install -y software-properties-common \
|
software-properties-common
|
||||||
&& add-apt-repository -y ppa:ondrej/php
|
|
||||||
|
|
||||||
# Install PHP-CLI 7 and some useful Tools
|
# Add the "PHP 7" ppa
|
||||||
RUN apt-get update \
|
RUN add-apt-repository -y \
|
||||||
&& apt-get install -y \
|
ppa:ondrej/php
|
||||||
|
|
||||||
|
# Install PHP-CLI 7, some PHP extentions and some useful Tools with APT
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
php7.0-cli \
|
php7.0-cli \
|
||||||
php7.0-common \
|
php7.0-common \
|
||||||
php7.0-curl \
|
php7.0-curl \
|
||||||
@ -27,7 +29,12 @@ RUN apt-get update \
|
|||||||
php7.0-mbstring \
|
php7.0-mbstring \
|
||||||
php7.0-mcrypt \
|
php7.0-mcrypt \
|
||||||
php7.0-mysql \
|
php7.0-mysql \
|
||||||
|
php7.0-pgsql \
|
||||||
|
php7.0-sqlite \
|
||||||
|
php7.0-sqlite3 \
|
||||||
php7.0-zip \
|
php7.0-zip \
|
||||||
|
sqlite3 \
|
||||||
|
libsqlite3-dev \
|
||||||
git \
|
git \
|
||||||
curl \
|
curl \
|
||||||
vim \
|
vim \
|
||||||
@ -36,29 +43,29 @@ RUN apt-get update \
|
|||||||
nodejs-dev \
|
nodejs-dev \
|
||||||
npm
|
npm
|
||||||
|
|
||||||
# Install Composer
|
# Clean up, to free some space
|
||||||
RUN curl -s http://getcomposer.org/installer | php \
|
RUN apt-get clean
|
||||||
&& mv composer.phar /usr/local/bin/ \
|
|
||||||
&& echo "alias composer='/usr/local/bin/composer.phar'" >> ~/.bashrc
|
|
||||||
|
|
||||||
# Install the Laravel Installer
|
# Install gulp and bower with NPM
|
||||||
RUN composer.phar global require "laravel/installer" \
|
RUN npm install -g \
|
||||||
&& echo "export PATH='~/.composer/vendor/bin:$PATH'" >> ~/.bashrc
|
gulp \
|
||||||
|
bower
|
||||||
|
|
||||||
# Install gulp and bower
|
# Add a symbolic link for Node
|
||||||
RUN npm install -g gulp bower
|
|
||||||
|
|
||||||
# Add a symbolic link
|
|
||||||
RUN ln -s /usr/bin/nodejs /usr/bin/node
|
RUN ln -s /usr/bin/nodejs /usr/bin/node
|
||||||
|
|
||||||
# Add an alias for PHPUnit
|
# Add an alias for PHPUnit
|
||||||
RUN echo "alias phpunit='./vendor/bin/phpunit'" >> ~/.bashrc
|
RUN echo "alias phpunit='./vendor/bin/phpunit'" >> ~/.bashrc
|
||||||
|
|
||||||
|
# Install Composer
|
||||||
|
RUN curl -s http://getcomposer.org/installer | php \
|
||||||
|
&& mv composer.phar /usr/local/bin/ \
|
||||||
|
&& echo "alias composer='/usr/local/bin/composer.phar'" >> ~/.bashrc
|
||||||
|
|
||||||
# Source the bash
|
# Source the bash
|
||||||
RUN . ~/.bashrc
|
RUN . ~/.bashrc
|
||||||
|
|
||||||
# Clean up
|
# Clean up
|
||||||
RUN apt-get autoclean && apt-get clean \
|
RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
|
||||||
|
|
||||||
WORKDIR /var/www/laravel
|
WORKDIR /var/www/laravel
|
||||||
|
Reference in New Issue
Block a user