-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathcluster-client.sh
executable file
·158 lines (118 loc) · 4.16 KB
/
cluster-client.sh
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
149
150
151
152
153
154
155
156
#!/bin/bash
set -uex
# assume already install: libgmp-dev nasm nlohmann-json3-dev snarkit plonkit
AS_RESOURCE=yes source ./run.sh
#IMAGE_AUTH_PASSWORD=1yhq8tvrcv44AlC
#IMAGE_HOST=registry.cn-wulanchabu.aliyuncs.com
#IMAGE_HOST_ALIAS=registry-vpc.cn-wulanchabu.aliyuncs.com
#IMAGE_REPO=fluidex-demo/prover
[[ -v IMAGE_REPO ]]
#COORDINATOR_EP=10.18.68.177
[[ -v COORDINATOR_EP ]]
[[ -v COORDINATOR_PORT ]] || COORDINATOR_PORT=50055
#COORDINATOR_SERV="http://cluster-coordinator:50055"
[[ -v CLIENT_REPLICAS ]] || CLIENT_REPLICAS=2
#CLUSTER_NS=test
CLUSTER_ORCHESTRA_DIR=$DIR/cluster-orchestra/prover-cluster
[[ -v STAGE ]] || STAGE=$(git rev-parse --short HEAD)
function cluster_submodule() {
git submodule init cluster-orchestra
}
function prepare_image() {
cd $CLUSTER_ORCHESTRA_DIR/images
docker build -f prover.docker -t prover .
TARGET_IMAGE=${IMAGE_HOST}/${IMAGE_REPO}:client-${STAGE}
echo "Will create and push image ${TARGET_IMAGE}"
cd ${TARGET_CIRCUIT_DIR}
docker build --no-cache -f $CLUSTER_ORCHESTRA_DIR/images/cluster_client_externalbuild.docker -t ${TARGET_IMAGE} .
if [[ -n $IMAGE_AUTH_USER ]]; then
docker login --username ${IMAGE_AUTH_USER} -p ${IMAGE_AUTH_PASSWORD} ${IMAGE_HOST}
fi
docker push ${TARGET_IMAGE}
}
function prepare_cluster() {
which ejs
if [ ! $? -eq 0 ]; then
sudo npm i -g ejs
fi
mkdir -p $WORK_DIR
set +u
STAGE=${STAGE} IMAGE_HOST=${IMAGE_HOST} IMAGE_REPO=${IMAGE_REPO} IMAGE_HOST_ALIAS=${IMAGE_HOST_ALIAS} IMAGE_AUTH_USER=${IMAGE_AUTH_USER} \
IMAGE_AUTH_PASSWORD=${IMAGE_AUTH_PASSWORD} CLIENT_REPLICAS=${CLIENT_REPLICAS} CLUSTER_NS=${CLUSTER_NS} CLUSTER_DEPLOYNAME=${CLUSTER_DEPLOYNAME} CIRCUIT=${CIRCUIT}\
COORDINATOR_EP=${COORDINATOR_EP} COORDINATOR_PORT=${COORDINATOR_PORT} COORDINATOR_SERV=${COORDINATOR_SERV} \
node cluster-data-gen.js > ${WORK_DIR}/data.json
set -u
template_dir=${CLUSTER_ORCHESTRA_DIR}/commonk8s
ejs ${template_dir}/0_configmaps.yaml.template -f ${WORK_DIR}/data.json -o ${WORK_DIR}/0_configmaps.yaml
if [[ -n $IMAGE_AUTH_USER ]]; then
ejs ${template_dir}/0_secrets_image.yaml.template -f ${WORK_DIR}/data.json -o ${WORK_DIR}/0_secrets_image.yaml
fi
ejs ${template_dir}/1_coordinator_ep.yaml.template -f ${WORK_DIR}/data.json -o ${WORK_DIR}/1_coordinator_ep.yaml
ejs ${template_dir}/2_services_external.yaml.template -f ${WORK_DIR}/data.json -o ${WORK_DIR}/2_services_external.yaml
ejs ${template_dir}/3_client.yaml.template -f ${WORK_DIR}/data.json -o ${WORK_DIR}/3_client.yaml
# kubectl apply -f ${WORK_DIR}/0_secrets_image.yaml
}
function deploy_cluster() {
cd ${WORK_DIR}
kubectl apply -f 0_secrets_image.yaml
kubectl apply -f 0_configmaps.yaml
kubectl apply -f 1_coordinator_ep.yaml
kubectl apply -f 2_services_external.yaml
kubectl apply -f 3_client.yaml
kubectl patch namespace ${OP_NS} -p "{\"metadata\":{\"annotations\":{\"stage\":\"${STAGE}\"}}}"
}
function reset_endpoint() {
kubectl apply -f 1_coordinator_ep.yaml
kubectl apply -f 2_services_external.yaml
}
function scale_cluster(){
replica=$1
if [[ -z ${replica} ]]; then
echo no replica
exit 1
fi
kubectl patch deployment prover-cli-t -n ${OP_NS} -p "{\"spec\":{\"replicas\":${replica}}}"
}
function tear_down() {
kubectl delete deployment prover-cli-t -n ${OP_NS}
kubectl delete secret img-cred -n ${OP_NS}
}
function setup_all() {
setup
cluster_submodule
prepare_image
config_prover_cluster
prepare_cluster
run_docker_compose
run_bin
[[ -v CLUSTER_NS ]] && create_ns
deploy_cluster
}
function run_all(){
setup_all
run_ticker
}
function create_ns(){
kubectl get namespace ${CLUSTER_NS}
if [ ! $? -eq 0 ]; then
kubectl create namespace ${CLUSTER_NS}
fi
}
#test k8s
which kubectl
if [ ! $? -eq 0 ]; then
echo "we need kubectl and config it to access an k8s cluster"
exit 1
fi
kubectl cluster-info
if [ ! $? -eq 0 ]; then
echo "k8s cluster can not be accessed normally"
exit 1
fi
WORK_DIR=/tmp/clibuild-${STAGE}
echo "would use stage ${STAGE}"
[[ -v CLUSTER_NS ]] && OP_NS=${CLUSTER_NS} || OP_NS=default
INSTALLED_STAGE=`kubectl get namespace ${OP_NS} -o=jsonpath='{.metadata.annotations.stage}'`
#function test_k8s() {
#}