-
Notifications
You must be signed in to change notification settings - Fork 0
/
docker.mk
96 lines (79 loc) · 3.1 KB
/
docker.mk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
include .env
default: up
DRUPAL_ROOT ?= /var/www/html/
## help : Print commands help.
.PHONY: help
ifneq (,$(wildcard docker.mk))
help : docker.mk
@sed -n 's/^##//p' $<
else
help : Makefile
@sed -n 's/^##//p' $<
endif
## up : Start containers.
.PHONY: up
up:
@echo "Starting up containers for $(PROJECT_NAME) with ssl"
chmod 600 docker/traefik/acme.json
docker-compose pull
docker-compose -f docker-compose.yml -f docker-compose.ssl.yml up -d --remove-orphans
.PHONY: mutagen
mutagen:
docker-compose up -d mutagen
mutagen project start -f mutagen/config.yml
## down : Stop containers.
.PHONY: down
down: stop
## start : Start containers without updating.
.PHONY: start
start:
@echo "Starting containers for $(PROJECT_NAME) from where you left off..."
@docker-compose start
## stop : Stop containers.
.PHONY: stop
stop:
@echo "Stopping containers for $(PROJECT_NAME)..."
@docker-compose stop
## prune : Remove containers and their volumes.
## You can optionally pass an argument with the service name to prune single container
## prune mariadb : Prune `mariadb` container and remove its volumes.
## prune mariadb solr : Prune `mariadb` and `solr` containers and remove their volumes.
.PHONY: prune
prune:
@echo "Removing containers for $(PROJECT_NAME)..."
@docker-compose down -v $(filter-out $@,$(MAKECMDGOALS))
## ps : List running containers.
.PHONY: ps
ps:
@docker ps --filter name='$(PROJECT_NAME)*'
## shell : Access `php` container via shell.
## You can optionally pass an argument with a service name to open a shell on the specified container
.PHONY: shell
shell:
docker exec -ti -e COLUMNS=$(shell tput cols) -e LINES=$(shell tput lines) $(shell docker ps --filter name='$(PROJECT_NAME)_$(or $(filter-out $@,$(MAKECMDGOALS)), 'php')' --format "{{ .ID }}") sh
## drush : Executes `drush` command in a specified `DRUPAL_ROOT` directory (default is `/var/www/html/web`).
## To use "--flag" arguments include them in quotation marks.
## For example: make drush "watchdog:show --type=cron"
.PHONY: drush
drush:
docker exec $(shell docker ps --filter name='^/$(PROJECT_NAME)_php' --format "{{ .ID }}") drush -r $(DRUPAL_ROOT) $(filter-out $@,$(MAKECMDGOALS))
## logs : View containers logs.
## You can optinally pass an argument with the service name to limit logs
## logs php : View `php` container logs.
## logs nginx php : View `nginx` and `php` containers logs.
.PHONY: logs
logs:
@docker-compose logs -f $(filter-out $@,$(MAKECMDGOALS))
## cert-test : Test generation of SSL certificate using `certbot`.
.PHONY: cert-test
cert-test:
@echo "Testing SSL certificate setup for $(PROJECT_NAME)"
docker-compose -f docker-compose.yml -f docker-compose.certbot.yml run --rm certbot certonly --webroot --webroot-path /var/www/certbot/ --dry-run -d $(PROJECT_BASE_URL)
## cert : Generate SSL certificate with letsencrypt `certbot certonly` command.
.PHONY: cert
cert:
@echo "Creating SSL certificate $(PROJECT_NAME)"
docker-compose -f docker-compose.yml -f docker-compose.certbot.yml run --rm certbot certonly --webroot --webroot-path /var/www/certbot/ -d $(PROJECT_BASE_URL)
# https://stackoverflow.com/a/6273809/1826109
%:
@: