96 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/usr/bin/env bash
 | |
| # Copyright 2023 The Karmada Authors.
 | |
| #
 | |
| # 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.
 | |
| 
 | |
| set -o errexit
 | |
| set -o nounset
 | |
| set -o pipefail
 | |
| 
 | |
| # This script starts a local karmada control plane with karmadactl and with a certain number of clusters joined.
 | |
| # This script depends on utils in: ${REPO_ROOT}/hack/util.sh
 | |
| # 1. used by developer to setup develop environment quickly.
 | |
| # 2. used by e2e testing to setup test environment automatically.
 | |
| 
 | |
| REPO_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
 | |
| source "${REPO_ROOT}"/hack/util.sh
 | |
| 
 | |
| # variable define
 | |
| KUBECONFIG_PATH=${KUBECONFIG_PATH:-"${HOME}/.kube"}
 | |
| HOST_CLUSTER_NAME=${HOST_CLUSTER_NAME:-"karmada-host"}
 | |
| MEMBER_CLUSTER_1_NAME=${MEMBER_CLUSTER_1_NAME:-"member1"}
 | |
| MEMBER_CLUSTER_2_NAME=${MEMBER_CLUSTER_2_NAME:-"member2"}
 | |
| CLUSTER_VERSION=${CLUSTER_VERSION:-"${DEFAULT_CLUSTER_VERSION}"}
 | |
| BUILD_PATH=${BUILD_PATH:-"_output/bin/linux/amd64"}
 | |
| 
 | |
| # prepare the newest crds
 | |
| echo "Prepare the newest crds"
 | |
| cd  charts/karmada/
 | |
| cp -r _crds crds
 | |
| tar -zcvf ../../crds.tar.gz crds
 | |
| cd -
 | |
| 
 | |
| # make images
 | |
| export VERSION="latest"
 | |
| export REGISTRY="docker.io/karmada"
 | |
| make images GOOS="linux" --directory="${REPO_ROOT}"
 | |
| 
 | |
| # make karmadactl binary
 | |
| make karmadactl
 | |
| 
 | |
| # create host/member1/member2 cluster
 | |
| echo "Start create clusters..."
 | |
| hack/create-cluster.sh ${HOST_CLUSTER_NAME} ${KUBECONFIG_PATH}/${HOST_CLUSTER_NAME}.config > /dev/null 2>&1 &
 | |
| hack/create-cluster.sh ${MEMBER_CLUSTER_1_NAME} ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_1_NAME}.config > /dev/null 2>&1 &
 | |
| hack/create-cluster.sh ${MEMBER_CLUSTER_2_NAME} ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_2_NAME}.config > /dev/null 2>&1 &
 | |
| 
 | |
| # wait cluster ready
 | |
| echo "Wait clusters ready..."
 | |
| util::wait_file_exist ${KUBECONFIG_PATH}/${HOST_CLUSTER_NAME}.config 300
 | |
| util::wait_context_exist ${HOST_CLUSTER_NAME} ${KUBECONFIG_PATH}/${HOST_CLUSTER_NAME}.config 300
 | |
| kubectl wait --for=condition=Ready nodes --all --timeout=800s --kubeconfig=${KUBECONFIG_PATH}/${HOST_CLUSTER_NAME}.config
 | |
| util::wait_nodes_taint_disappear 800 ${KUBECONFIG_PATH}/${HOST_CLUSTER_NAME}.config
 | |
| 
 | |
| util::wait_file_exist ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_1_NAME}.config 300
 | |
| util::wait_context_exist "${MEMBER_CLUSTER_1_NAME}" ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_1_NAME}.config 300
 | |
| kubectl wait --for=condition=Ready nodes --all --timeout=800s --kubeconfig=${KUBECONFIG_PATH}/${MEMBER_CLUSTER_1_NAME}.config
 | |
| util::wait_nodes_taint_disappear 800 ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_1_NAME}.config
 | |
| 
 | |
| util::wait_file_exist ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_2_NAME}.config 300
 | |
| util::wait_context_exist "${MEMBER_CLUSTER_2_NAME}" ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_2_NAME}.config 300
 | |
| kubectl wait --for=condition=Ready nodes --all --timeout=800s --kubeconfig=${KUBECONFIG_PATH}/${MEMBER_CLUSTER_2_NAME}.config
 | |
| util::wait_nodes_taint_disappear 800 ${KUBECONFIG_PATH}/${MEMBER_CLUSTER_2_NAME}.config
 | |
| 
 | |
| # load components images to kind cluster
 | |
| kind load docker-image "${REGISTRY}/karmada-controller-manager:${VERSION}" --name="${HOST_CLUSTER_NAME}"
 | |
| kind load docker-image "${REGISTRY}/karmada-scheduler:${VERSION}" --name="${HOST_CLUSTER_NAME}"
 | |
| kind load docker-image "${REGISTRY}/karmada-webhook:${VERSION}" --name="${HOST_CLUSTER_NAME}"
 | |
| kind load docker-image "${REGISTRY}/karmada-aggregated-apiserver:${VERSION}" --name="${HOST_CLUSTER_NAME}"
 | |
| 
 | |
| # init Karmada control plane
 | |
| echo "Start init karmada control plane..."
 | |
| ${BUILD_PATH}/karmadactl init --kubeconfig=${KUBECONFIG_PATH}/${HOST_CLUSTER_NAME}.config \
 | |
|     --karmada-controller-manager-image="${REGISTRY}/karmada-controller-manager:${VERSION}" \
 | |
|     --karmada-scheduler-image="${REGISTRY}/karmada-scheduler:${VERSION}" \
 | |
|     --karmada-webhook-image="${REGISTRY}/karmada-webhook:${VERSION}" \
 | |
|     --karmada-aggregated-apiserver-image="${REGISTRY}/karmada-aggregated-apiserver:${VERSION}" \
 | |
|     --karmada-data=${HOME}/karmada \
 | |
|     --karmada-pki=${HOME}/karmada/pki \
 | |
|     --crds=./crds.tar.gz
 | |
| 
 | |
| # join cluster
 | |
| echo "Join member clusters..."
 | |
| ${BUILD_PATH}/karmadactl --kubeconfig ${HOME}/karmada/karmada-apiserver.config  join ${MEMBER_CLUSTER_1_NAME} --cluster-kubeconfig=${KUBECONFIG_PATH}/${MEMBER_CLUSTER_1_NAME}.config
 | |
| ${BUILD_PATH}/karmadactl --kubeconfig ${HOME}/karmada/karmada-apiserver.config  join ${MEMBER_CLUSTER_2_NAME} --cluster-kubeconfig=${KUBECONFIG_PATH}/${MEMBER_CLUSTER_2_NAME}.config
 | |
| kubectl wait --for=condition=Ready clusters --all --timeout=800s  --kubeconfig=${HOME}/karmada/karmada-apiserver.config
 |