Skip to content

Commit 603d14c

Browse files
committed
Added localup script.
Signed-off-by: Klaus Ma <[email protected]>
1 parent cbe3c00 commit 603d14c

File tree

1 file changed

+233
-0
lines changed

1 file changed

+233
-0
lines changed

hack/local-up-cluster.sh

+233
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,233 @@
1+
#!/bin/bash
2+
3+
if [ -z $GOPATH ]; then
4+
echo "Please set GOPATH to start the cluster :)"
5+
exit 1
6+
fi
7+
8+
K8S_HOME=$GOPATH/src/k8s.io/kubernetes
9+
VC_HOME=$GOPATH/src/volcano.sh/volcano
10+
11+
CERT_DIR=${VC_HOME}/volcano/certs
12+
13+
LOCALHOST="127.0.0.1"
14+
API_PORT="6443"
15+
16+
ROOT_CA=
17+
ROOT_CA_KEY=
18+
19+
SERVICE_ACCOUNT_KEY=${VC_HOME}/volcano/certs/service-account.key
20+
21+
function download_binaries {
22+
mkdir -p ${VC_HOME}/volcano/work ${VC_HOME}/volcano/logs ${VC_HOME}/volcano/certs ${VC_HOME}/volcano/config ${VC_HOME}/volcano/static-pods
23+
24+
# go get -u github.com/cloudflare/cfssl/cmd/...
25+
}
26+
27+
function build_binaries {
28+
echo "Building Kubernetes ...... "
29+
echo "$(
30+
cd $K8S_HOME
31+
make kubectl kube-controller-manager kube-apiserver kubelet kube-proxy
32+
)"
33+
34+
echo "Building Volcano ...... "
35+
echo "$(
36+
cd $VC_HOME
37+
make
38+
)"
39+
}
40+
41+
function create_certkey {
42+
local name=$1
43+
local cn=$2
44+
local org=$3
45+
46+
local hosts=""
47+
local SEP=""
48+
49+
shift 3
50+
while [ -n "${1:-}" ]; do
51+
hosts+="${SEP}\"$1\""
52+
SEP=","
53+
shift 1
54+
done
55+
56+
echo '{"CN":"'${cn}'","hosts":['${hosts}'],"key":{"algo":"rsa","size":2048},"names":[{"O":"'${org}'"}]}' \
57+
| cfssl gencert -ca=${CERT_DIR}/root.pem -ca-key=${CERT_DIR}/root-key.pem -config=${CERT_DIR}/root-ca-config.json - \
58+
| cfssljson -bare ${CERT_DIR}/$name
59+
}
60+
61+
function generate_cert_files {
62+
openssl genrsa -out "${SERVICE_ACCOUNT_KEY}" 2048 2>/dev/null
63+
64+
echo '{"signing":{"default":{"expiry":"8760h","usages":["signing","key encipherment","server auth","client auth"]}}}' \
65+
> ${CERT_DIR}/root-ca-config.json
66+
67+
echo '{"CN":"volcano","key":{"algo":"rsa","size":2048},"names":[{"O":"volcano"}]}' | cfssl gencert -initca - \
68+
| cfssljson -bare ${CERT_DIR}/root
69+
70+
create_certkey "kube-apiserver" "kubernetes.default" "volcano" "kubernetes.default.svc" "localhost" "127.0.0.1" "10.0.0.1"
71+
create_certkey "admin" "system:admin" "system:masters"
72+
create_certkey "kube-proxy" "system:kube-proxy" "volcano"
73+
create_certkey "kubelet" "system:node:127.0.0.1" "system:nodes"
74+
create_certkey "controller-manager" "system:kube-controller-manager" "volcano"
75+
create_certkey "scheduler" "system:scheduler" "volcano"
76+
}
77+
78+
function write_kube_config {
79+
local name=$1
80+
81+
kubectl config set-cluster local --server=https://${LOCALHOST}:6443 --certificate-authority=${CERT_DIR}/root.pem \
82+
--kubeconfig ${VC_HOME}/volcano/config/${name}.config
83+
84+
kubectl config set-credentials myself --client-key=${CERT_DIR}/${name}-key.pem \
85+
--client-certificate=${CERT_DIR}/${name}.pem --kubeconfig ${VC_HOME}/volcano/config/${name}.config
86+
87+
kubectl config set-context local --cluster=local --user=myself --kubeconfig ${VC_HOME}/volcano/config/${name}.config
88+
kubectl config use-context local --kubeconfig ${VC_HOME}/volcano/config/${name}.config
89+
90+
# kubectl --kubeconfig ./controller-manager.config config view --minify --flatten > ${TOP_DIR}/volcano/config/controller-manager.config
91+
}
92+
93+
function start_etcd {
94+
nohup ${K8S_HOME}/third_party/etcd/etcd \
95+
--advertise-client-urls="http://${LOCALHOST}:2379" \
96+
--listen-client-urls="http://0.0.0.0:2379" \
97+
--data-dir=${VC_HOME}/volcano/work/etcd \
98+
--debug > ${VC_HOME}/volcano/logs/etcd.log 2>&1 &
99+
}
100+
101+
function start_apiserver {
102+
103+
nohup ${K8S_HOME}/_output/bin/kube-apiserver \
104+
--logtostderr="false" \
105+
--log-file=${VC_HOME}/volcano/logs/kube-apiserver.log \
106+
--service-account-key-file=${SERVICE_ACCOUNT_KEY} \
107+
--etcd-servers="http://${LOCALHOST}:2379" \
108+
--cert-dir=${CERT_DIR} \
109+
--tls-cert-file=${CERT_DIR}/kube-apiserver.pem \
110+
--tls-private-key-file=${CERT_DIR}/kube-apiserver-key.pem \
111+
--client-ca-file=${CERT_DIR}/root.pem \
112+
--kubelet-client-certificate=${CERT_DIR}/kube-apiserver.pem \
113+
--kubelet-client-key=${CERT_DIR}/kube-apiserver-key.pem \
114+
--insecure-bind-address=0.0.0.0 \
115+
--secure-port=${API_PORT} \
116+
--storage-backend=etcd3 \
117+
--feature-gates=AllAlpha=false \
118+
--service-cluster-ip-range=10.0.0.0/24 &
119+
}
120+
121+
function start_controller_manager {
122+
123+
write_kube_config "controller-manager"
124+
125+
nohup ${VC_HOME}/_output/bin/vc-controllers \
126+
--v=3 \
127+
--logtostderr=false \
128+
--log-file=${VC_HOME}/volcano/logs/vc-controllers.log \
129+
--scheduler-name=default \
130+
--kubeconfig=${VC_HOME}/volcano/config/controller-manager.config &
131+
132+
nohup ${K8S_HOME}/_output/bin/kube-controller-manager \
133+
--v=3 \
134+
--logtostderr="false" \
135+
--log-file=${VC_HOME}/volcano/logs/kube-controller-manager.log \
136+
--service-account-private-key-file=${SERVICE_ACCOUNT_KEY} \
137+
--root-ca-file=${CERT_DIR}/root.pem \
138+
--cluster-signing-cert-file=${CERT_DIR}/root.pem \
139+
--cluster-signing-key-file=${CERT_DIR}/root-key.pem \
140+
--enable-hostpath-provisioner=false \
141+
--pvclaimbinder-sync-period=15s \
142+
--feature-gates=AllAlpha=false \
143+
--kubeconfig ${VC_HOME}/volcano/config/controller-manager.config \
144+
--use-service-account-credentials \
145+
--controllers=* \
146+
--leader-elect=false \
147+
--cert-dir=${CERT_DIR} &
148+
}
149+
150+
function start_kubelet {
151+
152+
write_kube_config "kubelet"
153+
154+
nohup ${K8S_HOME}/_output/bin/kubelet \
155+
--logtostderr="false" \
156+
--log-file=${VC_HOME}/volcano/logs/kubelet.log \
157+
--chaos-chance=0.0 \
158+
--container-runtime=docker \
159+
--hostname-override=${LOCALHOST} \
160+
--address=${LOCALHOST} \
161+
--kubeconfig ${VC_HOME}/volcano/config/kubelet.config \
162+
--feature-gates=AllAlpha=false \
163+
--cpu-cfs-quota=true \
164+
--enable-controller-attach-detach=true \
165+
--cgroups-per-qos=true \
166+
--cgroup-driver=cgroupfs \
167+
--eviction-hard='memory.available<100Mi,nodefs.available<10%,nodefs.inodesFree<5%' \
168+
--eviction-pressure-transition-period=1m \
169+
--pod-manifest-path=${VC_HOME}/volcano/static-pods \
170+
--fail-swap-on=false \
171+
--authorization-mode=Webhook \
172+
--authentication-token-webhook \
173+
--client-ca-file=${CERT_DIR}/root.pem \
174+
--cluster-dns=10.0.0.10 \
175+
--cluster-domain=cluster.local \
176+
--runtime-request-timeout=2m \
177+
--port=10250 &
178+
}
179+
180+
function start_volcano_scheduler {
181+
write_kube_config "scheduler"
182+
183+
nohup ${VC_HOME}/_output/bin/vc-scheduler \
184+
--v=4 \
185+
--logtostderr=false \
186+
--listen-address=":8090" \
187+
--log-file=${VC_HOME}/volcano/logs/vc-scheduler.log \
188+
--scheduler-name=default \
189+
--kubeconfig=${VC_HOME}/volcano/config/scheduler.config &
190+
}
191+
192+
function start_volcano_admission {
193+
pwd
194+
}
195+
196+
function cleanup_cluster {
197+
killall -9 etcd kube-apiserver kube-controller-manager kubelet vc-controllers vc-scheduler vc-admission
198+
rm -rf ${VC_HOME}/volcano
199+
200+
# Waiting for TIME_WAIT
201+
sleep 6
202+
}
203+
204+
function apply_crds {
205+
for crd in scheduling_v1alpha2_podgroup.yaml batch_v1alpha1_job.yaml scheduling_v1alpha1_podgroup.yaml scheduling_v1alpha2_queue.yaml bus_v1alpha1_command.yaml scheduling_v1alpha1_queue.yaml default-queue.yaml
206+
do
207+
kubectl apply -f ${VC_HOME}/installer/helm/chart/volcano/templates/$crd --kubeconfig ${VC_HOME}/volcano/config/admin.config
208+
done
209+
210+
}
211+
212+
cleanup_cluster
213+
214+
download_binaries
215+
216+
# build_binaries
217+
218+
generate_cert_files
219+
220+
start_etcd
221+
start_apiserver
222+
223+
write_kube_config "admin"
224+
225+
apply_crds
226+
227+
start_controller_manager
228+
start_volcano_admission
229+
start_volcano_scheduler
230+
start_kubelet
231+
232+
233+

0 commit comments

Comments
 (0)