-
Notifications
You must be signed in to change notification settings - Fork 2
/
Makefile
148 lines (114 loc) · 4.29 KB
/
Makefile
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
SERVICE_NAME ?= nameko-multi-region-example-products
RABBIT_NAME ?= nameko-multi-region-example-rabbitmq
TAG ?= latest
REGIONS ?= europe asia america
# Build Docker Images
build-base:
docker build -t nameko-multi-region-base -f docker/base.docker .;
build-wheelbuilder:
docker build -t $(SERVICE_NAME)-builder -f docker/build.docker .;
run-wheelbuilder:
docker run --rm \
-v "$$(pwd)":/application -v "$$(pwd)"/wheelhouse:/wheelhouse \
$(SERVICE_NAME)-builder;
build-service:
docker build -t $(SERVICE_NAME):$(TAG) \
-f docker/run.docker .;
build-rabbit:
docker build -t $(RABBIT_NAME):$(TAG) \
-f docker/rabbit.docker .;
build-all: build-base build-wheelbuilder run-wheelbuilder build-service build-rabbit
push-to-docker-hub:
docker tag $(SERVICE_NAME):$(TAG) jakubborys/$(SERVICE_NAME):$(TAG)
docker tag $(RABBIT_NAME):$(TAG) jakubborys/$(RABBIT_NAME):$(TAG)
docker push jakubborys/$(SERVICE_NAME):$(TAG)
docker push jakubborys/$(RABBIT_NAME):$(TAG)
# Provision Docker Hosts for each Region
create-machines:
@for region in $(REGIONS) ; do \
docker-machine create --driver virtualbox $$region; \
done
deploy-services:
@for region in $(REGIONS) ; do \
eval $$(docker-machine env $$region) && \
docker-compose -f docker-compose/common.yml -f docker-compose/$$region.yml pull && \
docker-compose -f docker-compose/common.yml -f docker-compose/$$region.yml up -d --force-recreate; \
done
# RabbitMQ Federation Setup
federation-upstreams:
@for region in $(REGIONS) ; do \
eval $$(docker-machine env $$region) ; \
regions=($(REGIONS)) remove=$$region && upstream_hosts="$${regions[@]/$$remove}" ; \
for upstream_host in $$upstream_hosts ; do \
docker exec $(RABBIT_NAME) sh -c \
"rabbitmqctl set_parameter federation-upstream $$upstream_host-upstream \
'{\"uri\":\"amqp://$$(docker-machine ip $$upstream_host):5672\"}'" ; \
done \
done
federation-exchange-policy:
@for region in $(REGIONS) ; do \
eval $$(docker-machine env $$region) ; \
docker exec $(RABBIT_NAME) sh -c "rabbitmqctl set_policy --apply-to exchanges \
federated-exchanges \".*\.events$$\" '{\"federation-upstream-set\":\"all\"}'" ; \
done
federation-queue-policy:
@for region in $(REGIONS) ; do \
eval $$(docker-machine env $$region) ; \
docker exec $(RABBIT_NAME) sh -c "rabbitmqctl set_policy --apply-to queues \
federated-queues \"^(fed\..*)$$\" '{\"federation-upstream-set\":\"all\"}'" ; \
done
setup-federation: federation-upstreams federation-exchange-policy federation-queue-policy
build-and-deploy: build-all push-to-docker-hub deploy-services setup-federation
deploy: deploy-services setup-federation
coverage:
flake8 src test
coverage run --concurrency=eventlet --source=src -m pytest test $(ARGS)
coverage report -m --fail-under 100
# Handy utility commands
list-services:
@for region in $(REGIONS) ; do \
echo $$region && docker-machine ip $$region && \
eval $$(docker-machine env $$region) && docker ps; \
done
restart-services:
@for region in $(REGIONS) ; do \
eval $$(docker-machine env $$region) && docker restart nameko-multi-region-example-products; \
done
docker-command:
@eval $$(docker-machine env $(R)) && $(CMD)
start-hosts:
@for region in $(REGIONS) ; do \
docker-machine start $$region; \
docker-machine regenerate-certs $$region; \
done
stop-hosts:
@for region in $(REGIONS) ; do \
docker-machine stop $$region; \
done
cleanup-hosts:
@for region in $(REGIONS) ; do \
eval $$(docker-machine env $$region) && \
docker rm -f $(SERVICE_NAME) && docker rm -f $(RABBIT_NAME); \
done
run-rabbit:
docker run -d -p 15682:15672 --hostname rabbit \
-e RABBITMQ_ERLANG_COOKIE='24261958953861120' \
--name $(RABBIT_NAME) $(RABBIT_NAME):$(TAG)
run-service-container:
docker run -d -p 8090:8000 \
--link rabbit:$(RABBIT_NAME) -e RABBIT_HOST="rabbit" \
-e RABBIT_PORT="5672" -e RABBIT_MANAGEMENT_PORT="15672" \
--name $(SERVICE_NAME) $(SERVICE_NAME):$(TAG)
run-service:
nameko run --config config.yml src.service --backdoor 3000
# Commans from example
get-product:
curl 192.168.99.100:8000/products/1
add-product:
curl -XPOST 192.168.99.100:8000/products \
-d '{"price": "100.00", "name": "Tesla", "id": 1, "quantity": 100}'
order-product:
curl -XPOST 192.168.99.101:8000/orders \
-d '{"product_id": 1, "quantity": 1}'
calculate-tax:
curl -XPOST 192.168.99.100:8000/tax/asia