Merge pull request #5913 from chaosi-zju/test
simplify local-up-karmada.sh based on setup-dev-base.sh
This commit is contained in:
commit
471d850a19
|
@ -48,170 +48,44 @@ REPO_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
||||||
source "${REPO_ROOT}"/hack/util.sh
|
source "${REPO_ROOT}"/hack/util.sh
|
||||||
|
|
||||||
# variable define
|
# variable define
|
||||||
KUBECONFIG_PATH=${KUBECONFIG_PATH:-"${HOME}/.kube"}
|
export KUBECONFIG_PATH=${KUBECONFIG_PATH:-"${HOME}/.kube"}
|
||||||
MAIN_KUBECONFIG=${MAIN_KUBECONFIG:-"${KUBECONFIG_PATH}/karmada.config"}
|
export MAIN_KUBECONFIG=${MAIN_KUBECONFIG:-"${KUBECONFIG_PATH}/karmada.config"}
|
||||||
HOST_CLUSTER_NAME=${HOST_CLUSTER_NAME:-"karmada-host"}
|
export HOST_CLUSTER_NAME=${HOST_CLUSTER_NAME:-"karmada-host"}
|
||||||
KARMADA_APISERVER_CLUSTER_NAME=${KARMADA_APISERVER_CLUSTER_NAME:-"karmada-apiserver"}
|
export KARMADA_APISERVER_CLUSTER_NAME=${KARMADA_APISERVER_CLUSTER_NAME:-"karmada-apiserver"}
|
||||||
MEMBER_CLUSTER_KUBECONFIG=${MEMBER_CLUSTER_KUBECONFIG:-"${KUBECONFIG_PATH}/members.config"}
|
export MEMBER_CLUSTER_KUBECONFIG=${MEMBER_CLUSTER_KUBECONFIG:-"${KUBECONFIG_PATH}/members.config"}
|
||||||
MEMBER_CLUSTER_1_NAME=${MEMBER_CLUSTER_1_NAME:-"member1"}
|
export MEMBER_CLUSTER_1_NAME=${MEMBER_CLUSTER_1_NAME:-"member1"}
|
||||||
MEMBER_CLUSTER_2_NAME=${MEMBER_CLUSTER_2_NAME:-"member2"}
|
export MEMBER_CLUSTER_2_NAME=${MEMBER_CLUSTER_2_NAME:-"member2"}
|
||||||
PULL_MODE_CLUSTER_NAME=${PULL_MODE_CLUSTER_NAME:-"member3"}
|
export PULL_MODE_CLUSTER_NAME=${PULL_MODE_CLUSTER_NAME:-"member3"}
|
||||||
MEMBER_TMP_CONFIG_PREFIX="member-tmp"
|
export HOST_IPADDRESS=${1:-}
|
||||||
MEMBER_CLUSTER_1_TMP_CONFIG="${KUBECONFIG_PATH}/${MEMBER_TMP_CONFIG_PREFIX}-${MEMBER_CLUSTER_1_NAME}.config"
|
|
||||||
MEMBER_CLUSTER_2_TMP_CONFIG="${KUBECONFIG_PATH}/${MEMBER_TMP_CONFIG_PREFIX}-${MEMBER_CLUSTER_2_NAME}.config"
|
|
||||||
PULL_MODE_CLUSTER_TMP_CONFIG="${KUBECONFIG_PATH}/${MEMBER_TMP_CONFIG_PREFIX}-${PULL_MODE_CLUSTER_NAME}.config"
|
|
||||||
HOST_IPADDRESS=${1:-}
|
|
||||||
BUILD_FROM_SOURCE=${BUILD_FROM_SOURCE:-"true"}
|
|
||||||
|
|
||||||
CLUSTER_VERSION=${CLUSTER_VERSION:-"${DEFAULT_CLUSTER_VERSION}"}
|
# step1. set up a base development environment
|
||||||
KIND_LOG_FILE=${KIND_LOG_FILE:-"/tmp/karmada"}
|
"${REPO_ROOT}"/hack/setup-dev-base.sh
|
||||||
|
export KUBECONFIG="${MAIN_KUBECONFIG}"
|
||||||
|
|
||||||
#step0: prepare
|
# step2. install karmada control plane components
|
||||||
# proxy setting in China mainland
|
|
||||||
if [[ -n ${CHINA_MAINLAND:-} ]]; then
|
|
||||||
util::set_mirror_registry_for_china_mainland ${REPO_ROOT}
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Make sure go exists and the go version is a viable version.
|
|
||||||
util::cmd_must_exist "go"
|
|
||||||
util::verify_go_version
|
|
||||||
|
|
||||||
# Make sure docker is available
|
|
||||||
util::verify_docker
|
|
||||||
|
|
||||||
# install kind and kubectl
|
|
||||||
kind_version=v0.25.0
|
|
||||||
echo -n "Preparing: 'kind' existence check - "
|
|
||||||
if util::cmd_exist kind; then
|
|
||||||
echo "passed"
|
|
||||||
else
|
|
||||||
echo "not pass"
|
|
||||||
util::install_tools "sigs.k8s.io/kind" $kind_version
|
|
||||||
fi
|
|
||||||
# get arch name and os name in bootstrap
|
|
||||||
BS_ARCH=$(go env GOARCH)
|
|
||||||
BS_OS=$(go env GOOS)
|
|
||||||
# check arch and os name before installing
|
|
||||||
util::install_environment_check "${BS_ARCH}" "${BS_OS}"
|
|
||||||
echo -n "Preparing: 'kubectl' existence check - "
|
|
||||||
if util::cmd_exist kubectl; then
|
|
||||||
echo "passed"
|
|
||||||
else
|
|
||||||
echo "not pass"
|
|
||||||
util::install_kubectl "" "${BS_ARCH}" "${BS_OS}"
|
|
||||||
fi
|
|
||||||
#step1. create host cluster and member clusters in parallel
|
|
||||||
# host IP address: script parameter ahead of macOS IP
|
|
||||||
if [[ -z "${HOST_IPADDRESS}" ]]; then
|
|
||||||
util::get_macos_ipaddress # Adapt for macOS
|
|
||||||
HOST_IPADDRESS=${MAC_NIC_IPADDRESS:-}
|
|
||||||
fi
|
|
||||||
#prepare for kindClusterConfig
|
|
||||||
TEMP_PATH=$(mktemp -d)
|
|
||||||
trap '{ rm -rf ${TEMP_PATH}; }' EXIT
|
|
||||||
echo -e "Preparing kindClusterConfig in path: ${TEMP_PATH}"
|
|
||||||
cp -rf "${REPO_ROOT}"/artifacts/kindClusterConfig/member1.yaml "${TEMP_PATH}"/member1.yaml
|
|
||||||
cp -rf "${REPO_ROOT}"/artifacts/kindClusterConfig/member2.yaml "${TEMP_PATH}"/member2.yaml
|
|
||||||
cp -rf "${REPO_ROOT}"/artifacts/kindClusterConfig/member3.yaml "${TEMP_PATH}"/member3.yaml
|
|
||||||
|
|
||||||
util::delete_necessary_resources "${MAIN_KUBECONFIG},${MEMBER_CLUSTER_KUBECONFIG}" "${HOST_CLUSTER_NAME},${MEMBER_CLUSTER_1_NAME},${MEMBER_CLUSTER_2_NAME},${PULL_MODE_CLUSTER_NAME}" "${KIND_LOG_FILE}"
|
|
||||||
|
|
||||||
if [[ -n "${HOST_IPADDRESS}" ]]; then # If bind the port of clusters(karmada-host, member1 and member2) to the host IP
|
|
||||||
util::verify_ip_address "${HOST_IPADDRESS}"
|
|
||||||
cp -rf "${REPO_ROOT}"/artifacts/kindClusterConfig/karmada-host.yaml "${TEMP_PATH}"/karmada-host.yaml
|
|
||||||
sed -i'' -e "s/{{host_ipaddress}}/${HOST_IPADDRESS}/g" "${TEMP_PATH}"/karmada-host.yaml
|
|
||||||
sed -i'' -e 's/networking:/&\'$'\n'' apiServerAddress: "'${HOST_IPADDRESS}'"/' "${TEMP_PATH}"/member1.yaml
|
|
||||||
sed -i'' -e 's/networking:/&\'$'\n'' apiServerAddress: "'${HOST_IPADDRESS}'"/' "${TEMP_PATH}"/member2.yaml
|
|
||||||
sed -i'' -e 's/networking:/&\'$'\n'' apiServerAddress: "'${HOST_IPADDRESS}'"/' "${TEMP_PATH}"/member3.yaml
|
|
||||||
util::create_cluster "${HOST_CLUSTER_NAME}" "${MAIN_KUBECONFIG}" "${CLUSTER_VERSION}" "${KIND_LOG_FILE}" "${TEMP_PATH}"/karmada-host.yaml
|
|
||||||
else
|
|
||||||
util::create_cluster "${HOST_CLUSTER_NAME}" "${MAIN_KUBECONFIG}" "${CLUSTER_VERSION}" "${KIND_LOG_FILE}"
|
|
||||||
fi
|
|
||||||
util::create_cluster "${MEMBER_CLUSTER_1_NAME}" "${MEMBER_CLUSTER_1_TMP_CONFIG}" "${CLUSTER_VERSION}" "${KIND_LOG_FILE}" "${TEMP_PATH}"/member1.yaml
|
|
||||||
util::create_cluster "${MEMBER_CLUSTER_2_NAME}" "${MEMBER_CLUSTER_2_TMP_CONFIG}" "${CLUSTER_VERSION}" "${KIND_LOG_FILE}" "${TEMP_PATH}"/member2.yaml
|
|
||||||
util::create_cluster "${PULL_MODE_CLUSTER_NAME}" "${PULL_MODE_CLUSTER_TMP_CONFIG}" "${CLUSTER_VERSION}" "${KIND_LOG_FILE}" "${TEMP_PATH}"/member3.yaml
|
|
||||||
|
|
||||||
#step2. make images and get karmadactl
|
|
||||||
export VERSION="latest"
|
|
||||||
export REGISTRY="docker.io/karmada"
|
|
||||||
if [[ "${BUILD_FROM_SOURCE}" == "true" ]]; then
|
|
||||||
export KARMADA_IMAGE_LABEL_VALUE="May_be_pruned_in_local-up-karmada.sh"
|
|
||||||
export DOCKER_BUILD_ARGS="${DOCKER_BUILD_ARGS:-} --label=image.karmada.io=${KARMADA_IMAGE_LABEL_VALUE}"
|
|
||||||
make images GOOS="linux" --directory="${REPO_ROOT}"
|
|
||||||
#clean up dangling images
|
|
||||||
docker image prune --force --filter "label=image.karmada.io=${KARMADA_IMAGE_LABEL_VALUE}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
GO111MODULE=on go install "github.com/karmada-io/karmada/cmd/karmadactl"
|
|
||||||
GOPATH=$(go env GOPATH | awk -F ':' '{print $1}')
|
|
||||||
KARMADACTL_BIN="${GOPATH}/bin/karmadactl"
|
|
||||||
|
|
||||||
#step3. wait until the host cluster ready
|
|
||||||
echo "Waiting for the host clusters to be ready..."
|
|
||||||
util::check_clusters_ready "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}"
|
|
||||||
|
|
||||||
#step4. load components images to kind cluster
|
|
||||||
if [[ "${BUILD_FROM_SOURCE}" == "true" ]]; then
|
|
||||||
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-descheduler:${VERSION}" --name="${HOST_CLUSTER_NAME}"
|
|
||||||
kind load docker-image "${REGISTRY}/karmada-webhook:${VERSION}" --name="${HOST_CLUSTER_NAME}"
|
|
||||||
kind load docker-image "${REGISTRY}/karmada-scheduler-estimator:${VERSION}" --name="${HOST_CLUSTER_NAME}"
|
|
||||||
kind load docker-image "${REGISTRY}/karmada-aggregated-apiserver:${VERSION}" --name="${HOST_CLUSTER_NAME}"
|
|
||||||
kind load docker-image "${REGISTRY}/karmada-search:${VERSION}" --name="${HOST_CLUSTER_NAME}"
|
|
||||||
kind load docker-image "${REGISTRY}/karmada-metrics-adapter:${VERSION}" --name="${HOST_CLUSTER_NAME}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
#step5. install karmada control plane components
|
|
||||||
"${REPO_ROOT}"/hack/deploy-karmada.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}"
|
"${REPO_ROOT}"/hack/deploy-karmada.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}"
|
||||||
|
|
||||||
#step6. wait until the member cluster ready and join member clusters
|
# step3. join push mode member clusters and install scheduler-estimator
|
||||||
util::check_clusters_ready "${MEMBER_CLUSTER_1_TMP_CONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
GOPATH=$(go env GOPATH | awk -F ':' '{print $1}')
|
||||||
util::check_clusters_ready "${MEMBER_CLUSTER_2_TMP_CONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
KARMADACTL_BIN="${GOPATH}/bin/karmadactl"
|
||||||
|
${KARMADACTL_BIN} join --karmada-context="${KARMADA_APISERVER_CLUSTER_NAME}" ${MEMBER_CLUSTER_1_NAME} --cluster-kubeconfig="${MEMBER_CLUSTER_KUBECONFIG}" --cluster-context="${MEMBER_CLUSTER_1_NAME}"
|
||||||
|
"${REPO_ROOT}"/hack/deploy-scheduler-estimator.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}" "${MEMBER_CLUSTER_KUBECONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
||||||
|
${KARMADACTL_BIN} join --karmada-context="${KARMADA_APISERVER_CLUSTER_NAME}" ${MEMBER_CLUSTER_2_NAME} --cluster-kubeconfig="${MEMBER_CLUSTER_KUBECONFIG}" --cluster-context="${MEMBER_CLUSTER_2_NAME}"
|
||||||
|
"${REPO_ROOT}"/hack/deploy-scheduler-estimator.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}" "${MEMBER_CLUSTER_KUBECONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
||||||
|
|
||||||
# connecting networks between karmada-host, member1 and member2 clusters
|
# step4. register pull mode member clusters and install scheduler-estimator
|
||||||
echo "connecting cluster networks..."
|
"${REPO_ROOT}"/hack/deploy-agent-and-estimator.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}" "${MAIN_KUBECONFIG}" "${KARMADA_APISERVER_CLUSTER_NAME}" "${MEMBER_CLUSTER_KUBECONFIG}" "${PULL_MODE_CLUSTER_NAME}"
|
||||||
util::add_routes "${MEMBER_CLUSTER_1_NAME}" "${MEMBER_CLUSTER_2_TMP_CONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
|
||||||
util::add_routes "${MEMBER_CLUSTER_2_NAME}" "${MEMBER_CLUSTER_1_TMP_CONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
|
||||||
|
|
||||||
util::add_routes "${HOST_CLUSTER_NAME}" "${MEMBER_CLUSTER_1_TMP_CONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
# step5. deploy metrics-server in member clusters
|
||||||
util::add_routes "${MEMBER_CLUSTER_1_NAME}" "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}"
|
"${REPO_ROOT}"/hack/deploy-k8s-metrics-server.sh "${MEMBER_CLUSTER_KUBECONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
||||||
|
"${REPO_ROOT}"/hack/deploy-k8s-metrics-server.sh "${MEMBER_CLUSTER_KUBECONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
||||||
|
"${REPO_ROOT}"/hack/deploy-k8s-metrics-server.sh "${MEMBER_CLUSTER_KUBECONFIG}" "${PULL_MODE_CLUSTER_NAME}"
|
||||||
|
|
||||||
util::add_routes "${HOST_CLUSTER_NAME}" "${MEMBER_CLUSTER_2_TMP_CONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
# step6. wait all of clusters member1, member2 and member3 status is ready
|
||||||
util::add_routes "${MEMBER_CLUSTER_2_NAME}" "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}"
|
|
||||||
echo "cluster networks connected"
|
|
||||||
|
|
||||||
#join push mode member clusters
|
|
||||||
export KUBECONFIG="${MAIN_KUBECONFIG}"
|
|
||||||
${KARMADACTL_BIN} join --karmada-context="${KARMADA_APISERVER_CLUSTER_NAME}" ${MEMBER_CLUSTER_1_NAME} --cluster-kubeconfig="${MEMBER_CLUSTER_1_TMP_CONFIG}" --cluster-context="${MEMBER_CLUSTER_1_NAME}"
|
|
||||||
"${REPO_ROOT}"/hack/deploy-scheduler-estimator.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}" "${MEMBER_CLUSTER_1_TMP_CONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
|
||||||
${KARMADACTL_BIN} join --karmada-context="${KARMADA_APISERVER_CLUSTER_NAME}" ${MEMBER_CLUSTER_2_NAME} --cluster-kubeconfig="${MEMBER_CLUSTER_2_TMP_CONFIG}" --cluster-context="${MEMBER_CLUSTER_2_NAME}"
|
|
||||||
"${REPO_ROOT}"/hack/deploy-scheduler-estimator.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}" "${MEMBER_CLUSTER_2_TMP_CONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
|
||||||
|
|
||||||
# wait until the pull mode cluster ready
|
|
||||||
util::check_clusters_ready "${PULL_MODE_CLUSTER_TMP_CONFIG}" "${PULL_MODE_CLUSTER_NAME}"
|
|
||||||
if [[ "${BUILD_FROM_SOURCE}" == "true" ]]; then
|
|
||||||
kind load docker-image "${REGISTRY}/karmada-agent:${VERSION}" --name="${PULL_MODE_CLUSTER_NAME}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
#step7. deploy karmada agent in pull mode member clusters
|
|
||||||
"${REPO_ROOT}"/hack/deploy-agent-and-estimator.sh "${MAIN_KUBECONFIG}" "${HOST_CLUSTER_NAME}" "${MAIN_KUBECONFIG}" "${KARMADA_APISERVER_CLUSTER_NAME}" "${PULL_MODE_CLUSTER_TMP_CONFIG}" "${PULL_MODE_CLUSTER_NAME}"
|
|
||||||
|
|
||||||
#step8. deploy metrics-server in member clusters
|
|
||||||
"${REPO_ROOT}"/hack/deploy-k8s-metrics-server.sh "${MEMBER_CLUSTER_1_TMP_CONFIG}" "${MEMBER_CLUSTER_1_NAME}"
|
|
||||||
"${REPO_ROOT}"/hack/deploy-k8s-metrics-server.sh "${MEMBER_CLUSTER_2_TMP_CONFIG}" "${MEMBER_CLUSTER_2_NAME}"
|
|
||||||
"${REPO_ROOT}"/hack/deploy-k8s-metrics-server.sh "${PULL_MODE_CLUSTER_TMP_CONFIG}" "${PULL_MODE_CLUSTER_NAME}"
|
|
||||||
|
|
||||||
# wait all of clusters member1, member2 and member3 status is ready
|
|
||||||
util:wait_cluster_ready "${KARMADA_APISERVER_CLUSTER_NAME}" "${MEMBER_CLUSTER_1_NAME}"
|
util:wait_cluster_ready "${KARMADA_APISERVER_CLUSTER_NAME}" "${MEMBER_CLUSTER_1_NAME}"
|
||||||
util:wait_cluster_ready "${KARMADA_APISERVER_CLUSTER_NAME}" "${MEMBER_CLUSTER_2_NAME}"
|
util:wait_cluster_ready "${KARMADA_APISERVER_CLUSTER_NAME}" "${MEMBER_CLUSTER_2_NAME}"
|
||||||
util:wait_cluster_ready "${KARMADA_APISERVER_CLUSTER_NAME}" "${PULL_MODE_CLUSTER_NAME}"
|
util:wait_cluster_ready "${KARMADA_APISERVER_CLUSTER_NAME}" "${PULL_MODE_CLUSTER_NAME}"
|
||||||
|
|
||||||
#step9. merge temporary kubeconfig of member clusters by kubectl
|
|
||||||
export KUBECONFIG=$(find ${KUBECONFIG_PATH} -maxdepth 1 -type f | grep ${MEMBER_TMP_CONFIG_PREFIX} | tr '\n' ':')
|
|
||||||
kubectl config view --flatten > ${MEMBER_CLUSTER_KUBECONFIG}
|
|
||||||
rm $(find ${KUBECONFIG_PATH} -maxdepth 1 -type f | grep ${MEMBER_TMP_CONFIG_PREFIX})
|
|
||||||
|
|
||||||
function print_success() {
|
function print_success() {
|
||||||
echo -e "$KARMADA_GREETING"
|
echo -e "$KARMADA_GREETING"
|
||||||
echo "Local Karmada is running."
|
echo "Local Karmada is running."
|
||||||
|
|
Loading…
Reference in New Issue