163 lines
4.2 KiB
Markdown
163 lines
4.2 KiB
Markdown
|
|
# Materio 8.x Docker Environement
|
|
Materio powered by druapl 8 in docker environement (nginx, php:7-fpm+drush, phpmyadmin, redis)
|
|
|
|
## Install docker
|
|
```
|
|
sudo pacman -S docker docker-compose docker-machine
|
|
```
|
|
|
|
## Clone this repos
|
|
|
|
this will clone this repos (main docker environement) and the edlp drupal 8 source code (without sites/default folder)
|
|
|
|
```
|
|
git clone --recursive -o figli https://figureslibres.io/gogs/bachir/docker-materio-d8.git
|
|
```
|
|
|
|
### setup /sites/default/settings.php
|
|
|
|
```cp -r ressources/default public_html/sites/```
|
|
|
|
### get the sites/default/files folder
|
|
get the files from where you have it and rsync it to public_html/sites/default/files/
|
|
|
|
## Mysql
|
|
Copy your-sql-dump.sql into ./ressources/materio_d8.sql
|
|
It will be automaticly imported into the mysql container db (only) on the first docker-compose up
|
|
|
|
## Hosts and reverse proxy
|
|
|
|
add to your /etc/hosts :
|
|
```
|
|
127.0.0.1 dev.materio.com
|
|
127.0.0.1 dev.phpmyadmin.materio.com
|
|
```
|
|
configure your apache vhosts to add a reverse proxy that will redirect the dev.materio.com to our container
|
|
```
|
|
<Virtualhost *:80>
|
|
ServerName dev.materio.com
|
|
ProxyPass / http://127.0.0.1:8880/
|
|
ProxyPassReverse / http://127.0.0.1:8880/
|
|
ProxyRequests Off
|
|
ProxyPreserveHost On
|
|
proxy_buffer_size 128k;
|
|
proxy_buffers 4 256k;
|
|
proxy_busy_buffers_size 256k;
|
|
</Virtualhost>
|
|
```
|
|
```
|
|
<Virtualhost *:80>
|
|
ServerName dev.phpmyadmin.materio.com
|
|
ProxyPass / http://127.0.0.1:8881/
|
|
ProxyPassReverse / http://127.0.0.1:8881/
|
|
ProxyRequests Off
|
|
ProxyPreserveHost On
|
|
proxy_buffer_size 128k;
|
|
proxy_buffers 4 256k;
|
|
proxy_busy_buffers_size 256k;
|
|
</Virtualhost>
|
|
```
|
|
## Docker
|
|
|
|
### build
|
|
only before the first run (may take some time)
|
|
```
|
|
sudo docker-compose build
|
|
```
|
|
### run
|
|
then each time you want to launch the app
|
|
```
|
|
sudo docker-compose up -d
|
|
```
|
|
Be aware that a first up, since the db is empty, it will be populated with your file db.sql. It may take some time depending of your db size.
|
|
|
|
## Druapal Composer install
|
|
Only at first up, finish to install drupal composer dependencies
|
|
```
|
|
sudo docker exec -it materiod8_php_1 bash
|
|
composer install
|
|
```
|
|
|
|
## Visualize
|
|
You can now visit http://dev.materio.com on your browser
|
|
|
|
## Coding
|
|
### drush
|
|
you can access to drush by loging into the php container
|
|
```
|
|
sudo docker exec -it materiod8_php_1 bash
|
|
```
|
|
once inside the php container in /var/www/html you can use drush as usual
|
|
|
|
### gulp
|
|
Dev process needs gulp to run in:
|
|
- public_html/sites/all/modules/custom/materio/
|
|
- public_html/sites/all/themes/custom/materio/
|
|
if you have to modifie js or scss source code, you need to do in each of these 2 folder:
|
|
```
|
|
npm install
|
|
gulp
|
|
```
|
|
|
|
## updateding manualy mysql db
|
|
copy your db backup into the mysql container
|
|
```
|
|
sudo docker cp your-db-file.sql materiod8_mysql_1:/root/
|
|
```
|
|
log into mysql container
|
|
```
|
|
sudo docker exec -it materiod8_mysql_1 bash
|
|
```
|
|
once inside the mysql container you can use mysql command to drop then create and load the db with your file
|
|
|
|
## Makefile
|
|
|
|
do not use directly docker or docker-compose to run this instance
|
|
use make instead like ```make up```
|
|
|
|
```makefile
|
|
build:
|
|
docker-compose build --build-arg USER_UID=$(USER_UID) --build-arg USER_UNAME=$(USER_UNAME) --build-arg USER_GID=$(USER_GID) --build-arg USER_GNAME=$(USER_GNAME)
|
|
|
|
buildnc:
|
|
docker-compose build --no-cache --build-arg USER_UID=$(USER_UID) --build-arg USER_UNAME=$(USER_UNAME) --build-arg USER_GID=$(USER_GID) --build-arg USER_GNAME=$(USER_GNAME)
|
|
|
|
up:
|
|
docker-compose up -d
|
|
|
|
upbuild:
|
|
docker-compose up -d --build
|
|
|
|
ps:
|
|
docker-compose ps
|
|
|
|
logs:
|
|
docker-compose logs -f
|
|
|
|
down:
|
|
docker-compose down
|
|
|
|
php:
|
|
docker exec -it materiod8_php_1 bash
|
|
|
|
phplegacy:
|
|
docker exec -it materiod8_php-legacy_1 bash
|
|
```
|
|
|
|
|
|
# sources
|
|
https://www.ostraining.com/blog/drupal/docker/
|
|
|
|
http://tech.osteel.me/posts/2017/01/15/how-to-use-docker-for-local-web-development-an-update.html
|
|
|
|
https://mmenozzi.github.io/2016/01/22/php-web-development-with-docker/
|
|
|
|
https://dzone.com/articles/continuous-drupal-maintaining-a-drupal-website-wit//
|
|
|
|
https://github.com/glaux/drupal8docker
|
|
|
|
https://www.jeffgeerling.com/blogs/jeff-geerling/drupal-8-redis-php-7-nginx-and
|
|
|
|
https://chromatichq.com/blog/configuring-redis-caching-drupal-8
|