-
Notifications
You must be signed in to change notification settings - Fork 134
/
Copy pathMakefile
121 lines (106 loc) · 6.65 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
# Copyright 2018, Google, Inc.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
PROJECT_ID=$(shell gcloud config list project --format=flattened | awk 'FNR == 1 {print $$2}')
ZONE=us-west1-b
CLUSTER_NAME=my-istio-cluster
ZIPKIN_POD_NAME=$(shell kubectl -n istio-system get pod -l app=zipkin -o jsonpath='{.items[0].metadata.name}')
JAEGER_POD_NAME=$(shell kubectl -n istio-system get pod -l app=jaeger -o jsonpath='{.items[0].metadata.name}')
SERVICEGRAPH_POD_NAME=$(shell kubectl -n istio-system get pod -l app=servicegraph -o jsonpath='{.items[0].metadata.name}')
GRAFANA_POD_NAME=$(shell kubectl -n istio-system get pod -l app=grafana -o jsonpath='{.items[0].metadata.name}')
PROMETHEUS_POD_NAME=$(shell kubectl -n istio-system get pod -l app=prometheus -o jsonpath='{.items[0].metadata.name}')
GCLOUD_USER=$(shell gcloud config get-value core/account)
CONTAINER_NAME=istiotest
ISTIO_VERSION=1.0.5
download-istio:
wget https://github.com/istio/istio/releases/download/$(ISTIO_VERSION)/istio-$(ISTIO_VERSION)-linux.tar.gz
tar -zxvf istio-$(ISTIO_VERSION)-linux.tar.gz
genereate-istio-template:
helm template istio-$(ISTIO_VERSION)/install/kubernetes/helm/istio --name istio --namespace istio-system --set global.mtls.enabled=true --set tracing.enabled=true --set servicegraph.enabled=true --set grafana.enabled=true > istio.yaml
create-cluster:
gcloud container --project "$(PROJECT_ID)" clusters create "$(CLUSTER_NAME)" --zone "$(ZONE)" --machine-type "n1-standard-1" --image-type "COS" --disk-size "100" --scopes "https://www.googleapis.com/auth/compute","https://www.googleapis.com/auth/devstorage.read_only","https://www.googleapis.com/auth/logging.write","https://www.googleapis.com/auth/monitoring","https://www.googleapis.com/auth/servicecontrol","https://www.googleapis.com/auth/service.management.readonly","https://www.googleapis.com/auth/trace.append" --num-nodes "4" --network "default" --enable-cloud-logging --enable-cloud-monitoring --cluster-version=1.11 --addons HttpLoadBalancing --enable-autoupgrade --enable-autorepair
kubectl create clusterrolebinding cluster-admin-binding --clusterrole=cluster-admin --user=$(GCLOUD_USER)
deploy-istio:
-kubectl create namespace istio-system
kubectl apply -f istio.yaml
kubectl label namespace default istio-injection=enabled --overwrite
sleep 60
kubectl delete pod -n istio-system -l app=prometheus
create-istio-cluster:
gcloud beta container --project "$(PROJECT_ID)" clusters create "$(CLUSTER_NAME)" --zone "$(ZONE)" --machine-type "n1-standard-1" --image-type "COS" --disk-size "100" --scopes "https://www.googleapis.com/auth/compute","https://www.googleapis.com/auth/devstorage.read_only","https://www.googleapis.com/auth/logging.write","https://www.googleapis.com/auth/monitoring","https://www.googleapis.com/auth/servicecontrol","https://www.googleapis.com/auth/service.management.readonly","https://www.googleapis.com/auth/trace.append" --num-nodes "4" --network "default" --enable-cloud-logging --enable-cloud-monitoring --cluster-version=1.11 --addons HttpLoadBalancing,Istio --istio-config auth=MTLS_STRICT --enable-autoupgrade --enable-autorepair
kubectl create clusterrolebinding cluster-admin-binding --clusterrole=cluster-admin --user=$(GCLOUD_USER)
kubectl label namespace default istio-injection=enabled --overwrite
sleep 60
kubectl delete pod -n istio-system -l app=prometheus
deploy-stuff:
kubectl apply -f ./configs/kube/services.yaml
-sed -e 's~<PROJECT_ID>~$(PROJECT_ID)~g' ./configs/kube/deployments.yaml | kubectl apply -f -
get-stuff:
kubectl get pods && kubectl get svc && kubectl get svc istio-ingressgateway -n istio-system
ingress:
kubectl apply -f ./configs/istio/ingress.yaml
egress:
kubectl apply -f ./configs/istio/egress.yaml
prod:
kubectl apply -f ./configs/istio/destinationrules.yaml
kubectl apply -f ./configs/istio/routing-1.yaml
retry:
kubectl apply -f ./configs/istio/routing-2.yaml
canary:
kubectl apply -f ./configs/istio/routing-3.yaml
start-monitoring-services:
@echo "Jaeger: 16686 - Prometheus: 9090 - Grafana: 3000"
$(shell kubectl -n istio-system port-forward $(JAEGER_POD_NAME) 16686:16686 & kubectl -n istio-system port-forward $(SERVICEGRAPH_POD_NAME) 8088:8088 & kubectl -n istio-system port-forward $(GRAFANA_POD_NAME) 3000:3000 & kubectl -n istio-system port-forward $(PROMETHEUS_POD_NAME) 9090:9090)
build:
docker build -t gcr.io/$(PROJECT_ID)/istiotest:1.0 ./code/code-only-istio
docker build -t gcr.io/$(PROJECT_ID)/istio-opencensus-simple:1.0 ./code/code-opencensus-simple
docker build -t gcr.io/$(PROJECT_ID)/istio-opencensus-full:1.0 ./code/code-opencensus-full
push:
-gcloud auth configure-docker
docker push gcr.io/$(PROJECT_ID)/istiotest:1.0
docker push gcr.io/$(PROJECT_ID)/istio-opencensus-simple:1.0
docker push gcr.io/$(PROJECT_ID)/istio-opencensus-full:1.0
run-local:
docker run -ti --network host gcr.io/$(PROJECT_ID)/$(CONTAINER_NAME):1.0
restart-demo:
-kubectl delete svc --all
-kubectl delete deployment --all
-kubectl delete VirtualService --all
-kubectl delete DestinationRule --all
-kubectl delete Gateway --all
-kubectl delete ServiceEntry --all
uninstall-istio:
-kubectl delete ns istio-system
delete-cluster: uninstall-istio
-kubectl delete service frontend
-kubectl delete ingress istio-ingress
gcloud container clusters delete "$(CLUSTER_NAME)" --zone "$(ZONE)"
start-opencensus-demo: deploy-stuff ingress egress prod
deploy-opencensus-code:
kubectl apply -f ./configs/opencensus/config.yaml
-sed -e 's~<PROJECT_ID>~$(PROJECT_ID)~g' ./configs/opencensus/deployment.yaml | kubectl apply -f -
update-opencensus-deployment:
-sed -e 's~<PROJECT_ID>~$(PROJECT_ID)~g' ./configs/opencensus/deployment2.yaml | kubectl apply -f -
run-jaeger-local:
docker run -ti --name jaeger -e COLLECTOR_ZIPKIN_HTTP_PORT=9411 --network host jaegertracing/all-in-one:latest
run-standalone:
-kubectl create ns demo
kubectl run demo --image=gcr.io/$(PROJECT_ID)/$(CONTAINER_NAME):1.0 --namespace demo
expose-standalone:
kubectl expose deployment demo --target-port=3000 --port=80 --type=LoadBalancer --namespace demo
get-standalone:
kubectl get deployment --namespace demo
kubectl get pods --namespace demo
kubectl get svc --namespace demo
stop-standalone:
-kubectl delete svc demo --namespace demo
-kubectl delete ns demo